Add latest changes from gitlab-org/gitlab@master
This commit is contained in:
parent
b29d7709c1
commit
cc8ea69201
|
@ -54,8 +54,7 @@ export default {
|
|||
data() {
|
||||
return {
|
||||
email: this.initialEmail,
|
||||
// eslint-disable-next-line @gitlab/require-i18n-strings
|
||||
issuableName: this.issuableType === 'issue' ? 'issue' : 'merge request',
|
||||
issuableName: this.issuableType === 'issue' ? __('issue') : __('merge request'),
|
||||
};
|
||||
},
|
||||
computed: {
|
||||
|
|
|
@ -7,7 +7,7 @@ import { IssuableType } from '~/issuable_show/constants';
|
|||
import { IssuableStatus, IssueStateEvent } from '~/issue_show/constants';
|
||||
import { capitalizeFirstCharacter } from '~/lib/utils/text_utility';
|
||||
import { visitUrl } from '~/lib/utils/url_utility';
|
||||
import { __, sprintf } from '~/locale';
|
||||
import { s__, __, sprintf } from '~/locale';
|
||||
import eventHub from '~/notes/event_hub';
|
||||
import promoteToEpicMutation from '../queries/promote_to_epic.mutation.graphql';
|
||||
import updateIssueMutation from '../queries/update_issue.mutation.graphql';
|
||||
|
@ -78,10 +78,18 @@ export default {
|
|||
isClosed() {
|
||||
return this.openState === IssuableStatus.Closed;
|
||||
},
|
||||
issueTypeText() {
|
||||
const issueTypeTexts = {
|
||||
[IssuableType.Issue]: s__('HeaderAction|issue'),
|
||||
[IssuableType.Incident]: s__('HeaderAction|incident'),
|
||||
};
|
||||
|
||||
return issueTypeTexts[this.issueType] ?? this.issueType;
|
||||
},
|
||||
buttonText() {
|
||||
return this.isClosed
|
||||
? sprintf(__('Reopen %{issueType}'), { issueType: this.issueType })
|
||||
: sprintf(__('Close %{issueType}'), { issueType: this.issueType });
|
||||
? sprintf(__('Reopen %{issueType}'), { issueType: this.issueTypeText })
|
||||
: sprintf(__('Close %{issueType}'), { issueType: this.issueTypeText });
|
||||
},
|
||||
qaSelector() {
|
||||
return this.isClosed ? 'reopen_issue_button' : 'close_issue_button';
|
||||
|
|
|
@ -11,7 +11,6 @@ import httpStatusCodes from '~/lib/utils/http_status';
|
|||
import {
|
||||
capitalizeFirstCharacter,
|
||||
convertToCamelCase,
|
||||
splitCamelCase,
|
||||
slugifyWithUnderscore,
|
||||
} from '~/lib/utils/text_utility';
|
||||
import { sprintf } from '~/locale';
|
||||
|
@ -77,7 +76,15 @@ export default {
|
|||
]),
|
||||
...mapState(['isToggleStateButtonLoading']),
|
||||
noteableDisplayName() {
|
||||
return splitCamelCase(this.noteableType).toLowerCase();
|
||||
const displayNameMap = {
|
||||
[constants.ISSUE_NOTEABLE_TYPE]: this.$options.i18n.issue,
|
||||
[constants.EPIC_NOTEABLE_TYPE]: this.$options.i18n.epic,
|
||||
[constants.MERGE_REQUEST_NOTEABLE_TYPE]: this.$options.i18n.mergeRequest,
|
||||
};
|
||||
|
||||
const noteableTypeKey =
|
||||
constants.NOTEABLE_TYPE_MAPPING[this.noteableType] || constants.ISSUE_NOTEABLE_TYPE;
|
||||
return displayNameMap[noteableTypeKey];
|
||||
},
|
||||
isLoggedIn() {
|
||||
return this.getUserData.id;
|
||||
|
@ -103,15 +110,13 @@ export default {
|
|||
const openOrClose = this.isOpen ? 'close' : 'reopen';
|
||||
|
||||
if (this.note.length) {
|
||||
return sprintf(this.$options.i18n.actionButtonWithNote, {
|
||||
return sprintf(this.$options.i18n.actionButton.withNote[openOrClose], {
|
||||
actionText: this.commentButtonTitle,
|
||||
openOrClose,
|
||||
noteable: this.noteableDisplayName,
|
||||
});
|
||||
}
|
||||
|
||||
return sprintf(this.$options.i18n.actionButton, {
|
||||
openOrClose: capitalizeFirstCharacter(openOrClose),
|
||||
return sprintf(this.$options.i18n.actionButton.withoutNote[openOrClose], {
|
||||
noteable: this.noteableDisplayName,
|
||||
});
|
||||
},
|
||||
|
@ -151,13 +156,8 @@ export default {
|
|||
draftEndpoint() {
|
||||
return this.getNotesData.draftsPath;
|
||||
},
|
||||
issuableTypeTitle() {
|
||||
return this.noteableType === constants.MERGE_REQUEST_NOTEABLE_TYPE
|
||||
? this.$options.i18n.mergeRequest
|
||||
: this.$options.i18n.issue;
|
||||
},
|
||||
isIssue() {
|
||||
return this.noteableDisplayName === constants.ISSUE_NOTEABLE_TYPE;
|
||||
return constants.NOTEABLE_TYPE_MAPPING[this.noteableType] === constants.ISSUE_NOTEABLE_TYPE;
|
||||
},
|
||||
trackingLabel() {
|
||||
return slugifyWithUnderscore(`${this.commentButtonTitle} button`);
|
||||
|
@ -329,7 +329,7 @@ export default {
|
|||
<template>
|
||||
<div>
|
||||
<note-signed-out-widget v-if="!isLoggedIn" />
|
||||
<discussion-locked-widget v-else-if="!canCreateNote" :issuable-type="issuableTypeTitle" />
|
||||
<discussion-locked-widget v-else-if="!canCreateNote" :issuable-type="noteableDisplayName" />
|
||||
<ul v-else-if="canCreateNote" class="notes notes-form timeline">
|
||||
<timeline-entry-item class="note-form">
|
||||
<gl-alert
|
||||
|
|
|
@ -9,6 +9,7 @@ export const COMMENT_FORM = {
|
|||
issue: __('issue'),
|
||||
startThread: __('Start thread'),
|
||||
mergeRequest: __('merge request'),
|
||||
epic: __('epic'),
|
||||
bodyPlaceholder: __('Write a comment or drag your files here…'),
|
||||
confidential: s__('Notes|Make this comment confidential'),
|
||||
confidentialVisibility: s__('Notes|Confidential comments are only visible to project members'),
|
||||
|
@ -17,7 +18,16 @@ export const COMMENT_FORM = {
|
|||
),
|
||||
discussion: __('Discuss a specific suggestion or question.'),
|
||||
actionButtonWithNote: __('%{actionText} & %{openOrClose} %{noteable}'),
|
||||
actionButton: __('%{openOrClose} %{noteable}'),
|
||||
actionButton: {
|
||||
withNote: {
|
||||
reopen: __('%{actionText} & reopen %{noteable}'),
|
||||
close: __('%{actionText} & close %{noteable}'),
|
||||
},
|
||||
withoutNote: {
|
||||
reopen: __('Reopen %{noteable}'),
|
||||
close: __('Close %{noteable}'),
|
||||
},
|
||||
},
|
||||
submitButton: {
|
||||
startThread: __('Start thread'),
|
||||
comment: __('Comment'),
|
||||
|
|
|
@ -35,7 +35,7 @@ module FormHelper
|
|||
def assignees_dropdown_options(issuable_type)
|
||||
dropdown_data = {
|
||||
toggle_class: 'js-user-search js-assignee-search js-multiselect js-save-user-data',
|
||||
title: 'Select assignee',
|
||||
title: _('Select assignee'),
|
||||
filter: true,
|
||||
dropdown_class: 'dropdown-menu-user dropdown-menu-selectable dropdown-menu-assignee',
|
||||
placeholder: _('Search users'),
|
||||
|
@ -45,9 +45,9 @@ module FormHelper
|
|||
current_user: true,
|
||||
project_id: (@target_project || @project)&.id,
|
||||
field_name: "#{issuable_type}[assignee_ids][]",
|
||||
default_label: 'Unassigned',
|
||||
default_label: _('Unassigned'),
|
||||
'max-select': 1,
|
||||
'dropdown-header': 'Assignee',
|
||||
'dropdown-header': _('Assignee'),
|
||||
multi_select: true,
|
||||
'input-meta': 'name',
|
||||
'always-show-selectbox': true,
|
||||
|
@ -123,7 +123,7 @@ module FormHelper
|
|||
def multiple_assignees_dropdown_options(options)
|
||||
new_options = options.dup
|
||||
|
||||
new_options[:title] = 'Select assignee(s)'
|
||||
new_options[:title] = _('Select assignee(s)')
|
||||
new_options[:data][:'dropdown-header'] = 'Assignee(s)'
|
||||
new_options[:data].delete(:'max-select')
|
||||
|
||||
|
|
|
@ -6,7 +6,7 @@ module IssuablesDescriptionTemplatesHelper
|
|||
|
||||
def template_dropdown_tag(issuable, &block)
|
||||
selected_template = selected_template(issuable)
|
||||
title = selected_template || "Choose a template"
|
||||
title = selected_template || _('Choose a template')
|
||||
options = {
|
||||
toggle_class: 'js-issuable-selector',
|
||||
title: title,
|
||||
|
|
|
@ -80,7 +80,7 @@ module IssuablesHelper
|
|||
def users_dropdown_label(selected_users)
|
||||
case selected_users.length
|
||||
when 0
|
||||
"Unassigned"
|
||||
_('Unassigned')
|
||||
when 1
|
||||
selected_users[0].name
|
||||
else
|
||||
|
@ -133,7 +133,7 @@ module IssuablesHelper
|
|||
end
|
||||
# rubocop: enable CodeReuse/ActiveRecord
|
||||
|
||||
def milestone_dropdown_label(milestone_title, default_label = "Milestone")
|
||||
def milestone_dropdown_label(milestone_title, default_label = _('Milestone'))
|
||||
title =
|
||||
case milestone_title
|
||||
when Milestone::Upcoming.name then Milestone::Upcoming.title
|
||||
|
@ -188,7 +188,12 @@ module IssuablesHelper
|
|||
end
|
||||
|
||||
def issuables_state_counter_text(issuable_type, state, display_count)
|
||||
titles = { opened: "Open" }
|
||||
titles = {
|
||||
opened: _("Open"),
|
||||
closed: _("Closed"),
|
||||
merged: _("Merged"),
|
||||
all: _("All")
|
||||
}
|
||||
state_title = titles[state] || state.to_s.humanize
|
||||
html = content_tag(:span, state_title)
|
||||
|
||||
|
|
|
@ -25,10 +25,10 @@
|
|||
#{issuable_reference(issue)}
|
||||
%span.issuable-authored.d-none.d-sm-inline-block
|
||||
·
|
||||
created #{time_ago_with_tooltip(issue.created_at, placement: 'bottom')} by
|
||||
- if issue.service_desk_reply_to
|
||||
#{issue.service_desk_reply_to} via
|
||||
#{link_to_member(@project, issue.author, avatar: false)}
|
||||
#{_('created %{timeAgoString} by %{email} via %{user}').html_safe % { timeAgoString: time_ago_with_tooltip(issue.created_at, placement: 'bottom'), email: issue.service_desk_reply_to, user: link_to_member(@project, issue.author, avatar: false) }}
|
||||
- else
|
||||
#{s_('IssueList|created %{timeAgoString} by %{user}').html_safe % { timeAgoString: time_ago_with_tooltip(issue.created_at, placement: 'bottom'), user: link_to_member(@project, issue.author, avatar: false) }}
|
||||
= render_if_exists 'shared/issuable/gitlab_team_member_badge', author: issue.author
|
||||
- if issue.milestone
|
||||
%span.issuable-milestone.d-none.d-sm-inline-block
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
- if can?(current_user, :push_code, @project)
|
||||
- can_create_merge_request = can?(current_user, :create_merge_request_in, @project)
|
||||
- data_action = can_create_merge_request ? 'create-mr' : 'create-branch'
|
||||
- value = can_create_merge_request ? 'Create merge request' : 'Create branch'
|
||||
- value = can_create_merge_request ? _('Create merge request') : _('Create branch')
|
||||
- value = can_create_confidential_merge_request? ? _('Create confidential merge request') : value
|
||||
- create_mr_text = can_create_confidential_merge_request? ? _('Create confidential merge request') : _('Create merge request')
|
||||
|
||||
|
|
|
@ -20,8 +20,7 @@
|
|||
#{issuable_reference(merge_request)}
|
||||
%span.issuable-authored.d-none.d-sm-inline-block
|
||||
·
|
||||
created #{time_ago_with_tooltip(merge_request.created_at, placement: 'bottom')}
|
||||
by #{link_to_member(@project, merge_request.author, avatar: false)}
|
||||
#{s_('IssueList|created %{timeAgoString} by %{user}').html_safe % { timeAgoString: time_ago_with_tooltip(merge_request.created_at, placement: 'bottom'), user: link_to_member(@project, merge_request.author, avatar: false) }}
|
||||
= render_if_exists 'shared/issuable/gitlab_team_member_badge', author: merge_request.author
|
||||
- if merge_request.milestone
|
||||
%span.issuable-milestone.d-none.d-sm-inline-block
|
||||
|
|
|
@ -7,7 +7,7 @@
|
|||
- preview_url = preview_markdown_path(project, target_type: model.class.name)
|
||||
|
||||
.form-group.row.detail-page-description
|
||||
= form.label :description, 'Description', class: 'col-form-label col-sm-2'
|
||||
= form.label :description, _('Description'), class: 'col-form-label col-sm-2'
|
||||
.col-sm-10
|
||||
- if model.is_a?(MergeRequest)
|
||||
= hidden_field_tag :merge_request_diff_head_sha, model.diff_head_sha
|
||||
|
|
|
@ -64,7 +64,7 @@
|
|||
for this project.
|
||||
|
||||
- if issuable.new_record?
|
||||
= form.submit "Create #{issuable.class.model_name.human.downcase}", class: 'gl-button btn btn-confirm gl-mr-2', data: { qa_selector: 'issuable_create_button' }
|
||||
= form.submit "#{_('Create')} #{issuable.class.model_name.human.downcase}", class: 'gl-button btn btn-confirm gl-mr-2', data: { qa_selector: 'issuable_create_button' }
|
||||
- else
|
||||
= form.submit _('Save changes'), class: 'gl-button btn btn-confirm gl-mr-2'
|
||||
|
||||
|
|
|
@ -4,20 +4,20 @@
|
|||
- selected = local_assigns.fetch(:selected, nil)
|
||||
|
||||
- selected_text = selected.try(:title) || params[:milestone_title]
|
||||
- dropdown_title = local_assigns.fetch(:dropdown_title, "Filter by milestone")
|
||||
- dropdown_title = local_assigns.fetch(:dropdown_title, _('Filter by milestone'))
|
||||
- if selected.present? || params[:milestone_title].present?
|
||||
= hidden_field_tag(name, name == :milestone_title ? selected_text : selected.id)
|
||||
= dropdown_tag(milestone_dropdown_label(selected_text), options: { title: dropdown_title, toggle_class: "qa-issuable-milestone-dropdown js-milestone-select js-filter-submit #{extra_class}", filter: true, dropdown_class: "qa-issuable-dropdown-menu-milestone dropdown-menu-selectable dropdown-menu-milestone",
|
||||
placeholder: "Search milestones", footer_content: project.present?, data: { show_no: true, show_menu_above: show_menu_above, show_any: show_any, show_upcoming: show_upcoming, show_started: show_started, field_name: name, selected: selected_text, project_id: project.try(:id), default_label: "Milestone" } }) do
|
||||
placeholder: _('Search milestones'), footer_content: project.present?, data: { show_no: true, show_menu_above: show_menu_above, show_any: show_any, show_upcoming: show_upcoming, show_started: show_started, field_name: name, selected: selected_text, project_id: project.try(:id), default_label: _('Milestone') } }) do
|
||||
- if project
|
||||
%ul.dropdown-footer-list
|
||||
- if can? current_user, :admin_milestone, project
|
||||
%li
|
||||
= link_to new_project_milestone_path(project), title: "New Milestone" do
|
||||
Create new
|
||||
= link_to new_project_milestone_path(project), title: _('New Milestone') do
|
||||
= _('Create new')
|
||||
%li
|
||||
= link_to project_milestones_path(project) do
|
||||
- if can? current_user, :admin_milestone, project
|
||||
Manage milestones
|
||||
= _('Manage milestones')
|
||||
- else
|
||||
View milestones
|
||||
= _('View milestones')
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
%p.form-text.text-muted
|
||||
Add
|
||||
= link_to 'description templates', help_page_path('user/project/description_templates')
|
||||
to help your contributors communicate effectively!
|
||||
- template_link_url = help_page_path('user/project/description_templates')
|
||||
- template_link_start = '<a href="%{url}" target="_blank" rel="noopener noreferrer">'.html_safe % { url: template_link_url }
|
||||
= s_('Promotions|Add %{link_start} description templates %{link_end} to help your contributors to communicate effectively!').html_safe % { link_start: template_link_start, link_end: '</a>'.html_safe }
|
||||
|
||||
|
|
|
@ -10,7 +10,7 @@
|
|||
.form-check
|
||||
= form.check_box :confidential, class: 'form-check-input'
|
||||
= form.label :confidential, class: 'form-check-label' do
|
||||
This issue is confidential and should only be visible to team members with at least Reporter access.
|
||||
#{_('This issue is confidential and should only be visible to team members with at least Reporter access.')}
|
||||
|
||||
- if can?(current_user, :"set_#{issuable.to_ability_name}_metadata", issuable)
|
||||
%hr
|
||||
|
@ -27,13 +27,13 @@
|
|||
|
||||
- if issuable.supports_milestone?
|
||||
.form-group.row.issue-milestone
|
||||
= form.label :milestone_id, "Milestone", class: "col-form-label #{has_due_date ? "col-md-2 col-lg-4" : "col-sm-2"}"
|
||||
= form.label :milestone_id, _('Milestone'), class: "col-form-label #{has_due_date ? "col-md-2 col-lg-4" : "col-sm-2"}"
|
||||
.col-sm-10{ class: ("col-md-8" if has_due_date) }
|
||||
.issuable-form-select-holder
|
||||
= render "shared/issuable/milestone_dropdown", selected: issuable.milestone, name: "#{issuable.class.model_name.param_key}[milestone_id]", show_any: false, show_upcoming: false, show_started: false, extra_class: "qa-issuable-milestone-dropdown js-issuable-form-dropdown js-dropdown-keep-input", dropdown_title: "Select milestone"
|
||||
= render "shared/issuable/milestone_dropdown", selected: issuable.milestone, name: "#{issuable.class.model_name.param_key}[milestone_id]", show_any: false, show_upcoming: false, show_started: false, extra_class: "qa-issuable-milestone-dropdown js-issuable-form-dropdown js-dropdown-keep-input", dropdown_title: _('Select milestone')
|
||||
|
||||
.form-group.row
|
||||
= form.label :label_ids, "Labels", class: "col-form-label #{has_due_date ? "col-md-2 col-lg-4" : "col-sm-2"}"
|
||||
= form.label :label_ids, _('Labels'), class: "col-form-label #{has_due_date ? "col-md-2 col-lg-4" : "col-sm-2"}"
|
||||
= form.hidden_field :label_ids, multiple: true, value: ''
|
||||
.col-sm-10{ class: "#{"col-md-8" if has_due_date}" }
|
||||
.issuable-form-select-holder
|
||||
|
@ -45,7 +45,7 @@
|
|||
.col-lg-6
|
||||
= render_if_exists "shared/issuable/form/weight", issuable: issuable, form: form
|
||||
.form-group.row
|
||||
= form.label :due_date, "Due date", class: "col-form-label col-md-2 col-lg-4"
|
||||
= form.label :due_date, _('Due date'), class: "col-form-label col-md-2 col-lg-4"
|
||||
.col-8
|
||||
.issuable-form-select-holder
|
||||
= form.text_field :due_date, id: "issuable-due-date", class: "datepicker form-control", placeholder: "Select due date", autocomplete: 'off'
|
||||
= form.text_field :due_date, id: "issuable-due-date", class: "datepicker form-control", placeholder: _('Select due date'), autocomplete: 'off'
|
||||
|
|
|
@ -8,4 +8,4 @@
|
|||
= hidden_field_tag "#{issuable.to_ability_name}[assignee_ids][]", 0, id: nil, data: { meta: '' }
|
||||
|
||||
= dropdown_tag(users_dropdown_label(issuable.assignees), options: assignees_dropdown_options(issuable.to_ability_name))
|
||||
= link_to 'Assign to me', '#', class: "assign-to-me-link qa-assign-to-me-link #{'hide' if issuable.assignees.include?(current_user)}"
|
||||
= link_to _('Assign to me'), '#', class: "assign-to-me-link qa-assign-to-me-link #{'hide' if issuable.assignees.include?(current_user)}"
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
- return unless issuable.supports_issue_type? && can?(current_user, :create_issue, @project)
|
||||
|
||||
.form-group.row.gl-mb-0
|
||||
= form.label :type, 'Type', class: 'col-form-label col-sm-2'
|
||||
= form.label :type, _('Type'), class: 'col-form-label col-sm-2'
|
||||
.col-sm-10
|
||||
.gl-display-flex.gl-align-items-center
|
||||
.issuable-form-select-holder.selectbox.form-group.gl-mb-0
|
||||
|
|
|
@ -8,7 +8,7 @@ info: To determine the technical writer assigned to the Stage/Group associated w
|
|||
# JWT OmniAuth provider **(FREE SELF)**
|
||||
|
||||
To enable the JWT OmniAuth provider, you must register your application with JWT.
|
||||
JWT will provide you with a secret key for you to use.
|
||||
JWT provides you with a secret key for you to use.
|
||||
|
||||
1. On your GitLab server, open the configuration file.
|
||||
|
||||
|
@ -74,9 +74,9 @@ JWT will provide you with a secret key for you to use.
|
|||
installed GitLab via Omnibus or from source respectively.
|
||||
|
||||
On the sign in page there should now be a JWT icon below the regular sign in form.
|
||||
Click the icon to begin the authentication process. JWT will ask the user to
|
||||
Click the icon to begin the authentication process. JWT asks the user to
|
||||
sign in and authorize the GitLab application. If everything goes well, the user
|
||||
will be redirected to GitLab and will be signed in.
|
||||
is redirected to GitLab and signed in.
|
||||
|
||||
<!-- ## Troubleshooting
|
||||
|
||||
|
|
|
@ -64,7 +64,7 @@ Before following any of those steps, make sure you have `root` access to the
|
|||
promote a Geo replica and perform a failover.
|
||||
|
||||
NOTE:
|
||||
GitLab 13.9 through GitLab 14.3 are affected by a bug in which the Geo secondary site statuses will appear to stop updating and become unhealthy. For more information, see [Geo Admin Area shows 'Unhealthy' after enabling Maintenance Mode](../../replication/troubleshooting.md#geo-admin-area-shows-unhealthy-after-enabling-maintenance-mode).
|
||||
GitLab 13.9 through GitLab 14.3 are affected by a bug in which the Geo secondary site statuses appear to stop updating and become unhealthy. For more information, see [Geo Admin Area shows 'Unhealthy' after enabling Maintenance Mode](../../replication/troubleshooting.md#geo-admin-area-shows-unhealthy-after-enabling-maintenance-mode).
|
||||
|
||||
On the **secondary** site:
|
||||
|
||||
|
@ -88,7 +88,7 @@ A common cause of replication failures is the data being missing on the
|
|||
**primary** site - you can resolve these failures by restoring the data from backup,
|
||||
or removing references to the missing data.
|
||||
|
||||
The maintenance window won't end until Geo replication and verification is
|
||||
The maintenance window doesn't end until Geo replication and verification is
|
||||
completely finished. To keep the window as short as possible, you should
|
||||
ensure these processes are close to 100% as possible during active use.
|
||||
|
||||
|
@ -138,7 +138,7 @@ follow these steps to avoid unnecessary data loss:
|
|||
1. On the Sidekiq dhasboard, select **Cron**.
|
||||
1. Select `Disable All` to disable any non-Geo periodic background jobs.
|
||||
1. Select `Enable` for the `geo_sidekiq_cron_config_worker` cron job.
|
||||
This job will re-enable several other cron jobs that are essential for planned
|
||||
This job re-enables several other cron jobs that are essential for planned
|
||||
failover to complete successfully.
|
||||
|
||||
1. Finish replicating and verifying all data:
|
||||
|
|
|
@ -71,7 +71,7 @@ a single URL used by all Geo sites, including the primary.
|
|||
|
||||
## Disable Geo proxying
|
||||
|
||||
You can disable the secondary proxying on each Geo site, separately, by following these steps:
|
||||
You can disable the secondary proxying on each Geo site, separately, by following these steps with Omnibus-based packages:
|
||||
|
||||
1. SSH into each application node (serving user traffic directly) on your secondary Geo site
|
||||
and add the following environment variable:
|
||||
|
@ -92,6 +92,16 @@ You can disable the secondary proxying on each Geo site, separately, by followin
|
|||
gitlab-ctl reconfigure
|
||||
```
|
||||
|
||||
In Kubernetes, you can use `--set gitlab.webservice.extraEnv.GEO_SECONDARY_PROXY="0"`,
|
||||
or specify the following in your values file:
|
||||
|
||||
```yaml
|
||||
gitlab:
|
||||
webservice:
|
||||
extraEnv:
|
||||
GEO_SECONDARY_PROXY: "0"
|
||||
```
|
||||
|
||||
## Enable Geo proxying with Separate URLs
|
||||
|
||||
The ability to use proxying with separate URLs is still in development. You can follow the
|
||||
|
@ -105,6 +115,10 @@ SSH into one node running Rails on your primary Geo site and run:
|
|||
sudo gitlab-rails runner "Feature.enable(:geo_secondary_proxy_separate_urls)"
|
||||
```
|
||||
|
||||
In Kubernetes, you can run the same command in the toolbox pod. Refer to the
|
||||
[Kubernetes cheat sheet](../../troubleshooting/kubernetes_cheat_sheet.md#gitlab-specific-kubernetes-information)
|
||||
for details.
|
||||
|
||||
## Limitations
|
||||
|
||||
The asynchronous Geo replication can cause unexpected issues when secondary proxying is used, for accelerated
|
||||
|
|
|
@ -91,32 +91,37 @@ and can be removed at any time without notice.
|
|||
|
||||
### Deprecation and Removal process
|
||||
|
||||
Parts of the schema marked for removal from the GitLab GraphQL API are first **deprecated** but still available
|
||||
for at least six releases, and then **removed entirely**.
|
||||
Removals occur at `X.0` and `X.6` releases.
|
||||
The deprecation and removal process for the GitLab GraphQL API aligns with the wider GitLab
|
||||
[deprecation process](https://about.gitlab.com/handbook/product/gitlab-the-product/#breaking-changes-deprecations-and-removing-features).
|
||||
|
||||
The process is as follows:
|
||||
Parts of the schema marked for removal from the GitLab GraphQL API are first [deprecated](https://about.gitlab.com/handbook/product/gitlab-the-product/#deprecation) but still available
|
||||
for at least six releases, and then [removed](https://about.gitlab.com/handbook/product/gitlab-the-product/#removal) entirely. Removals occur on `XX.0` major releases.
|
||||
|
||||
1. The item is marked as deprecated in the schema. It will be displayed as deprecated in the
|
||||
[GraphQL API Reference](reference/index.md) and in introspection queries.
|
||||
1. Removals are announced at least one release prior in the [Deprecations](https://about.gitlab.com/handbook/marketing/blog/release-posts/#deprecations)
|
||||
section of the release post (at or prior to `X.11` and `X.5` releases).
|
||||
1. Items meeting criteria are removed in `X.0` or `X.6` and added to:
|
||||
Items are marked as deprecated [in the schema](https://spec.graphql.org/October2021/#sec--deprecated),
|
||||
and are also displayed as deprecated in:
|
||||
|
||||
- The [Removals](https://about.gitlab.com/handbook/marketing/blog/release-posts/#removals) section of the Release Post.
|
||||
- The [Removed items page](removed_items.md).
|
||||
- The [GraphQL API reference](reference/index.md).
|
||||
- The [deprecation feature removal schedule](../../update/deprecations.md), which is linked to in release posts.
|
||||
- Introspection queries of the GraphQL API.
|
||||
|
||||
This gives consumers of the GraphQL API a minimum of six months to update their GraphQL queries.
|
||||
NOTE:
|
||||
Consumers of the GraphQL API are encouraged to remove the use of deprecated schema in their GraphQL
|
||||
API calls as soon as possible to avoid experiencing breaking changes.
|
||||
|
||||
When an item is deprecated or removed, an alternative is provided if available.
|
||||
If an alternative is provided for the deprecated schema item, then its deprecation message mentions this.
|
||||
|
||||
**Example:**
|
||||
|
||||
A field marked as deprecated in `12.7` can be used until its removal in `13.6`.
|
||||
The following fields could both be removed in `14.0`:
|
||||
|
||||
| Field deprecated in | Reason |
|
||||
| --- | --- |
|
||||
| `12.7` | As GitLab traditionally has 12 minor releases per major release, the next major release that occurs 6 months after the field was deprecated is `14.0`, rather than `13.0`. |
|
||||
| `13.6` | The removal in `14.0` allows for 6 months of deprecation. |
|
||||
|
||||
### List of removed items
|
||||
|
||||
View the [fields, enums, and other items we removed](removed_items.md) from the GraphQL API.
|
||||
View the [list of items removed](removed_items.md) in previous releases.
|
||||
|
||||
## Available queries
|
||||
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
---
|
||||
stage: Plan
|
||||
group: Product Planning
|
||||
stage: Ecosystem
|
||||
group: Integrations
|
||||
info: To determine the technical writer assigned to the Stage/Group associated with this page, see https://about.gitlab.com/handbook/engineering/ux/technical-writing/#assignments
|
||||
---
|
||||
|
||||
|
@ -38,6 +38,8 @@ Fields [removed](https://gitlab.com/gitlab-org/gitlab/-/merge_requests/63293) in
|
|||
|
||||
## GitLab 13.6
|
||||
|
||||
Prior to GitLab 14.0, deprecated items could be removed in `XX.6` releases.
|
||||
|
||||
Fields [removed](https://gitlab.com/gitlab-org/gitlab/-/merge_requests/44866) in GitLab 13.6:
|
||||
|
||||
| Field name | GraphQL type | Deprecated in | Use instead |
|
||||
|
|
|
@ -207,7 +207,7 @@ The following Elasticsearch settings are available:
|
|||
| `Password` | The password of your Elasticsearch instance. |
|
||||
| `Number of Elasticsearch shards` | Elasticsearch indexes are split into multiple shards for performance reasons. In general, you should use at least 5 shards, and indexes with tens of millions of documents need to have more shards ([see below](#guidance-on-choosing-optimal-cluster-configuration)). Changes to this value do not take effect until the index is recreated. You can read more about tradeoffs in the [Elasticsearch documentation](https://www.elastic.co/guide/en/elasticsearch/reference/current/scalability.html). |
|
||||
| `Number of Elasticsearch replicas` | Each Elasticsearch shard can have a number of replicas. These are a complete copy of the shard, and can provide increased query performance or resilience against hardware failure. Increasing this value increases total disk space required by the index. |
|
||||
| `Limit namespaces and projects that can be indexed` | Enabling this allows you to select namespaces and projects to index. All other namespaces and projects use database search instead. If you enable this option but do not select any namespaces or projects, none will be indexed. [Read more below](#limit-namespaces-and-projects).
|
||||
| `Limit namespaces and projects that can be indexed` | Enabling this allows you to select namespaces and projects to index. All other namespaces and projects use database search instead. If you enable this option but do not select any namespaces or projects, none are indexed. [Read more below](#limit-namespaces-and-projects).
|
||||
| `Using AWS hosted Elasticsearch with IAM credentials` | Sign your Elasticsearch requests using [AWS IAM authorization](https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_access-keys.html), [AWS EC2 Instance Profile Credentials](https://docs.aws.amazon.com/codedeploy/latest/userguide/getting-started-create-iam-instance-profile.html#getting-started-create-iam-instance-profile-cli), or [AWS ECS Tasks Credentials](https://docs.aws.amazon.com/AmazonECS/latest/userguide/task-iam-roles.html). Please refer to [Identity and Access Management in Amazon Elasticsearch Service](https://docs.aws.amazon.com/elasticsearch-service/latest/developerguide/es-ac.html) for details of AWS hosted Elasticsearch domain access policy configuration. |
|
||||
| `AWS Region` | The AWS region in which your Elasticsearch service is located. |
|
||||
| `AWS Access Key` | The AWS access key. |
|
||||
|
@ -233,7 +233,7 @@ If you select `Limit namespaces and projects that can be indexed`, more options
|
|||
You can select namespaces and projects to index exclusively. Note that if the namespace is a group, it includes
|
||||
any subgroups and projects belonging to those subgroups to be indexed as well.
|
||||
|
||||
Advanced Search only provides cross-group code/commit search (global) if all name-spaces are indexed. In this particular scenario where only a subset of namespaces are indexed, a global search will not provide a code or commit scope. This is possible only in the scope of an indexed namespace. There is no way to code/commit search in multiple indexed namespaces (when only a subset of namespaces has been indexed). For example if two groups are indexed, there is no way to run a single code search on both. You can only run a code search on the first group and then on the second.
|
||||
Advanced Search only provides cross-group code/commit search (global) if all name-spaces are indexed. In this particular scenario where only a subset of namespaces are indexed, a global search does not provide a code or commit scope. This is possible only in the scope of an indexed namespace. There is no way to code/commit search in multiple indexed namespaces (when only a subset of namespaces has been indexed). For example if two groups are indexed, there is no way to run a single code search on both. You can only run a code search on the first group and then on the second.
|
||||
|
||||
You can filter the selection dropdown by writing part of the namespace or project name you're interested in.
|
||||
|
||||
|
@ -355,7 +355,7 @@ Setting this value too high can have adverse performance impacts as your cluster
|
|||
may become heavily saturated with searches and writes. Setting this value too
|
||||
low may lead the reindexing process to take a very long time to complete.
|
||||
|
||||
The best value for this will depend on your cluster size, whether you're willing
|
||||
The best value for this depends on your cluster size, whether you're willing
|
||||
to accept some degraded search performance during reindexing, and how important
|
||||
it is for the reindex to finish quickly and resume indexing.
|
||||
|
||||
|
@ -430,23 +430,23 @@ In order to debug issues with the migrations you can check the [`elasticsearch.l
|
|||
### Retry a halted migration
|
||||
|
||||
Some migrations are built with a retry limit. If the migration cannot finish within the retry limit,
|
||||
it will be halted and a notification will be displayed in the Advanced Search integration settings.
|
||||
it is halted and a notification is displayed in the Advanced Search integration settings.
|
||||
It is recommended to check the [`elasticsearch.log` file](../administration/logs.md#elasticsearchlog) to
|
||||
debug why the migration was halted and make any changes before retrying the migration. Once you believe you've
|
||||
fixed the cause of the failure, click "Retry migration", and the migration will be scheduled to be retried
|
||||
fixed the cause of the failure, click "Retry migration", and the migration is scheduled to be retried
|
||||
in the background.
|
||||
|
||||
If you cannot get the migration to succeed, you may
|
||||
consider the [last resort to recreate the index from
|
||||
scratch](#last-resort-to-recreate-an-index). This may allow you to skip over
|
||||
the problem because a newly created index will skip all migrations as the index
|
||||
will be recreated with the correct up-to-date schema.
|
||||
the problem because a newly created index skips all migrations as the index
|
||||
is recreated with the correct up-to-date schema.
|
||||
|
||||
### All migrations must be finished before doing a major upgrade
|
||||
|
||||
Before doing a major version GitLab upgrade, you should have completed all
|
||||
migrations that exist up until the latest minor version before that major
|
||||
version. If you have halted migrations, these will need to be resolved and
|
||||
version. If you have halted migrations, these need to be resolved and
|
||||
[retried](#retry-a-halted-migration) before proceeding with a major version
|
||||
upgrade. Read more about [upgrading to a new major
|
||||
version](../update/index.md#upgrading-to-a-new-major-version).
|
||||
|
@ -468,7 +468,7 @@ The following are some available Rake tasks:
|
|||
| [`sudo gitlab-rake gitlab:elastic:resume_indexing`](https://gitlab.com/gitlab-org/gitlab/-/blob/master/ee/lib/tasks/gitlab/elastic.rake) | Resumes Elasticsearch indexing. |
|
||||
| [`sudo gitlab-rake gitlab:elastic:index_projects`](https://gitlab.com/gitlab-org/gitlab/-/blob/master/ee/lib/tasks/gitlab/elastic.rake) | Iterates over all projects and queues Sidekiq jobs to index them in the background. |
|
||||
| [`sudo gitlab-rake gitlab:elastic:index_projects_status`](https://gitlab.com/gitlab-org/gitlab/-/blob/master/ee/lib/tasks/gitlab/elastic.rake) | Determines the overall status of the indexing. It is done by counting the total number of indexed projects, dividing by a count of the total number of projects, then multiplying by 100. |
|
||||
| [`sudo gitlab-rake gitlab:elastic:clear_index_status`](https://gitlab.com/gitlab-org/gitlab/-/blob/master/ee/lib/tasks/gitlab/elastic.rake) | Deletes all instances of IndexStatus for all projects. Note that this command will result in a complete wipe of the index, and it should be used with caution. |
|
||||
| [`sudo gitlab-rake gitlab:elastic:clear_index_status`](https://gitlab.com/gitlab-org/gitlab/-/blob/master/ee/lib/tasks/gitlab/elastic.rake) | Deletes all instances of IndexStatus for all projects. Note that this command results in a complete wipe of the index, and it should be used with caution. |
|
||||
| [`sudo gitlab-rake gitlab:elastic:create_empty_index`](https://gitlab.com/gitlab-org/gitlab/-/blob/master/ee/lib/tasks/gitlab/elastic.rake) | Generates empty indexes (the default index and a separate issues index) and assigns an alias for each on the Elasticsearch side only if it doesn't already exist. |
|
||||
| [`sudo gitlab-rake gitlab:elastic:delete_index`](https://gitlab.com/gitlab-org/gitlab/-/blob/master/ee/lib/tasks/gitlab/elastic.rake) | Removes the GitLab indexes and aliases (if they exist) on the Elasticsearch instance. |
|
||||
| [`sudo gitlab-rake gitlab:elastic:recreate_index`](https://gitlab.com/gitlab-org/gitlab/-/blob/master/ee/lib/tasks/gitlab/elastic.rake) | Wrapper task for `gitlab:elastic:delete_index` and `gitlab:elastic:create_empty_index`. |
|
||||
|
@ -501,7 +501,7 @@ I, [2019-03-04T21:27:05.215266 #3384] INFO -- : Indexing GitLab User / test (ID
|
|||
|
||||
## Advanced Search index scopes
|
||||
|
||||
When performing a search, the GitLab index will use the following scopes:
|
||||
When performing a search, the GitLab index uses the following scopes:
|
||||
|
||||
| Scope Name | What it searches |
|
||||
| ---------------- | ---------------------- |
|
||||
|
@ -521,25 +521,25 @@ When performing a search, the GitLab index will use the following scopes:
|
|||
|
||||
For basic guidance on choosing a cluster configuration you may refer to [Elastic Cloud Calculator](https://cloud.elastic.co/pricing). You can find more information below.
|
||||
|
||||
- Generally, you will want to use at least a 2-node cluster configuration with one replica, which will allow you to have resilience. If your storage usage is growing quickly, you may want to plan horizontal scaling (adding more nodes) beforehand.
|
||||
- It's not recommended to use HDD storage with the search cluster, because it will take a hit on performance. It's better to use SSD storage (NVMe or SATA SSD drives for example).
|
||||
- Generally, you want to use at least a 2-node cluster configuration with one replica, which allows you to have resilience. If your storage usage is growing quickly, you may want to plan horizontal scaling (adding more nodes) beforehand.
|
||||
- It's not recommended to use HDD storage with the search cluster, because it takes a hit on performance. It's better to use SSD storage (NVMe or SATA SSD drives for example).
|
||||
- You can use the [GitLab Performance Tool](https://gitlab.com/gitlab-org/quality/performance) to benchmark search performance with different search cluster sizes and configurations.
|
||||
- `Heap size` should be set to no more than 50% of your physical RAM. Additionally, it shouldn't be set to more than the threshold for zero-based compressed oops. The exact threshold varies, but 26 GB is safe on most systems, but can also be as large as 30 GB on some systems. See [Heap size settings](https://www.elastic.co/guide/en/elasticsearch/reference/current/important-settings.html#heap-size-settings) and [Setting JVM options](https://www.elastic.co/guide/en/elasticsearch/reference/current/jvm-options.html) for more details.
|
||||
- Number of CPUs (CPU cores) per node usually corresponds to the `Number of Elasticsearch shards` setting described below.
|
||||
- A good guideline is to ensure you keep the number of shards per node below 20 per GB heap it has configured. A node with a 30GB heap should therefore have a maximum of 600 shards, but the further below this limit you can keep it the better. This will generally help the cluster stay in good health.
|
||||
- A good guideline is to ensure you keep the number of shards per node below 20 per GB heap it has configured. A node with a 30GB heap should therefore have a maximum of 600 shards, but the further below this limit you can keep it the better. This generally helps the cluster stay in good health.
|
||||
- Number of Elasticsearch shards:
|
||||
- Small shards result in small segments, which increases overhead. Aim to keep the average shard size between at least a few GB and a few tens of GB.
|
||||
- Another consideration is the number of documents. To determine the number of shards to use, sum the numbers in the **Menu > Admin > Dashboard > Statistics** pane (the number of documents to be indexed), divide by 5 million, and add 5. For example:
|
||||
- If you have fewer than about 2,000,000 documents, use the default of 5 shards
|
||||
- 10,000,000 documents: `10000000/5000000 + 5` = 7 shards
|
||||
- 100,000,000 documents: `100000000/5000000 + 5` = 25 shards
|
||||
- `refresh_interval` is a per index setting. You may want to adjust that from default `1s` to a bigger value if you don't need data in real-time. This will change how soon you will see fresh results. If that's important for you, you should leave it as close as possible to the default value.
|
||||
- `refresh_interval` is a per index setting. You may want to adjust that from default `1s` to a bigger value if you don't need data in real-time. This changes how soon you see fresh results. If that's important for you, you should leave it as close as possible to the default value.
|
||||
- You might want to raise [`indices.memory.index_buffer_size`](https://www.elastic.co/guide/en/elasticsearch/reference/current/indexing-buffer.html) to 30% or 40% if you have a lot of heavy indexing operations.
|
||||
|
||||
### Advanced Search integration settings guidance
|
||||
|
||||
- The `Number of Elasticsearch shards` setting usually corresponds with the number of CPUs available in your cluster. For example, if you have a 3-node cluster with 4 cores each, this means you will benefit from having at least 3*4=12 shards in the cluster. It's only possible to change the shards number by using [Split index API](https://www.elastic.co/guide/en/elasticsearch/reference/current/indices-split-index.html) or by reindexing to a different index with a changed number of shards.
|
||||
- The `Number of Elasticsearch replicas` setting should most of the time be equal to `1` (each shard will have 1 replica). Using `0` is not recommended, because losing one node will corrupt the index.
|
||||
- The `Number of Elasticsearch shards` setting usually corresponds with the number of CPUs available in your cluster. For example, if you have a 3-node cluster with 4 cores each, this means you benefit from having at least 3*4=12 shards in the cluster. It's only possible to change the shards number by using [Split index API](https://www.elastic.co/guide/en/elasticsearch/reference/current/indices-split-index.html) or by reindexing to a different index with a changed number of shards.
|
||||
- The `Number of Elasticsearch replicas` setting should most of the time be equal to `1` (each shard has 1 replica). Using `0` is not recommended, because losing one node corrupts the index.
|
||||
|
||||
### Indexing large instances
|
||||
|
||||
|
@ -548,7 +548,7 @@ This section may be helpful in the event that the other
|
|||
due to large volumes of data being indexed.
|
||||
|
||||
WARNING:
|
||||
Indexing a large instance will generate a lot of Sidekiq jobs.
|
||||
Indexing a large instance generates a lot of Sidekiq jobs.
|
||||
Make sure to prepare for this task by having a [Scalable and Highly Available
|
||||
Setup](../administration/reference_architectures/index.md) or creating [extra
|
||||
Sidekiq processes](../administration/operations/extra_sidekiq_processes.md).
|
||||
|
|
|
@ -118,12 +118,12 @@ The following table lists the data available for each official analyzer.
|
|||
| File | ✓ | ⚠ | ✓ |
|
||||
| Start line | 𐄂 | 𐄂 | 𐄂 |
|
||||
| End line | 𐄂 | 𐄂 | 𐄂 |
|
||||
| External ID (e.g., CVE) | ✓ | ✓ | ⚠ |
|
||||
| External ID (for example, CVE) | ✓ | ✓ | ⚠ |
|
||||
| URLs | ✓ | ✓ | ✓ |
|
||||
| Internal doc/explanation | ✓ | 𐄂 | 𐄂 |
|
||||
| Solution | ✓ | ✓ | 𐄂 |
|
||||
| Confidence | 𐄂 | 𐄂 | 𐄂 |
|
||||
| Affected item (e.g. class or package) | ✓ | ✓ | ✓ |
|
||||
| Affected item (for example, class or package) | ✓ | ✓ | ✓ |
|
||||
| Source code extract | 𐄂 | 𐄂 | 𐄂 |
|
||||
| Internal ID | ✓ | 𐄂 | 𐄂 |
|
||||
| Date | ✓ | 𐄂 | 𐄂 |
|
||||
|
@ -134,4 +134,4 @@ The following table lists the data available for each official analyzer.
|
|||
- 𐄂 => we don't have that data, or it would need to develop specific or inefficient/unreliable logic to obtain it.
|
||||
|
||||
The values provided by these tools are heterogeneous, so they are sometimes
|
||||
normalized into common values (e.g., `severity`, `confidence`, etc).
|
||||
normalized into common values (for example, `severity`, `confidence`, etc).
|
||||
|
|
|
@ -176,7 +176,7 @@ For that, a `SETUP_CMD` CI/CD variable can be passed to the container,
|
|||
with the required commands to run before the license detection.
|
||||
|
||||
If present, this variable overrides the setup step necessary to install all the packages
|
||||
of your application (e.g.: for a project with a `Gemfile`, the setup step could be
|
||||
of your application (for example: for a project with a `Gemfile`, the setup step could be
|
||||
`bundle install`).
|
||||
|
||||
For example:
|
||||
|
|
|
@ -149,7 +149,7 @@ Supported values are:
|
|||
| Name | Example |
|
||||
| ----- | ------- |
|
||||
| `bar` | ![Insights example bar chart](img/insights_example_bar_chart.png) |
|
||||
| `bar` (time series, i.e. when `group_by` is used) | ![Insights example bar time series chart](img/insights_example_bar_time_series_chart.png) |
|
||||
| `bar` (time series, that is when `group_by` is used) | ![Insights example bar time series chart](img/insights_example_bar_time_series_chart.png) |
|
||||
| `line` | ![Insights example stacked bar chart](img/insights_example_line_chart.png) |
|
||||
| `stacked-bar` | ![Insights example stacked bar chart](img/insights_example_stacked_bar_chart.png) |
|
||||
|
||||
|
|
|
@ -66,7 +66,7 @@ you matching code from each project you have access to.
|
|||
Full details can be found in the [Elasticsearch documentation](https://www.elastic.co/guide/en/elasticsearch/reference/5.3/query-dsl-simple-query-string-query.html#_simple_query_string_syntax), but
|
||||
here's a quick guide:
|
||||
|
||||
- Searches look for all the words in a query, in any order - e.g.: searching
|
||||
- Searches look for all the words in a query, in any order - for example: searching
|
||||
issues for [`display bug`](https://gitlab.com/search?snippets=&scope=issues&repository_ref=&search=display+bug&group_id=9970&project_id=278964) and [`bug display`](https://gitlab.com/search?snippets=&scope=issues&repository_ref=&search=bug+Display&group_id=9970&project_id=278964) will return the same results.
|
||||
- To find the exact phrase (stemming still applies), use double quotes: [`"display bug"`](https://gitlab.com/search?snippets=&scope=issues&repository_ref=&search=%22display+bug%22&group_id=9970&project_id=278964)
|
||||
- To find bugs not mentioning display, use `-`: [`bug -display`](https://gitlab.com/search?snippets=&scope=issues&repository_ref=&search=bug+-display&group_id=9970&project_id=278964)
|
||||
|
|
|
@ -419,6 +419,12 @@ msgstr[1] ""
|
|||
msgid "%{actionText} & %{openOrClose} %{noteable}"
|
||||
msgstr ""
|
||||
|
||||
msgid "%{actionText} & close %{noteable}"
|
||||
msgstr ""
|
||||
|
||||
msgid "%{actionText} & reopen %{noteable}"
|
||||
msgstr ""
|
||||
|
||||
msgid "%{address} is an invalid IP address range"
|
||||
msgstr ""
|
||||
|
||||
|
@ -811,9 +817,6 @@ msgstr ""
|
|||
msgid "%{oneYearAgo} - %{today}"
|
||||
msgstr ""
|
||||
|
||||
msgid "%{openOrClose} %{noteable}"
|
||||
msgstr ""
|
||||
|
||||
msgid "%{openedEpics} open, %{closedEpics} closed"
|
||||
msgstr ""
|
||||
|
||||
|
@ -4724,6 +4727,9 @@ msgstr ""
|
|||
msgid "Assign to commenting user"
|
||||
msgstr ""
|
||||
|
||||
msgid "Assign to me"
|
||||
msgstr ""
|
||||
|
||||
msgid "Assign yourself to these issues"
|
||||
msgstr ""
|
||||
|
||||
|
@ -7308,6 +7314,9 @@ msgstr ""
|
|||
msgid "Close %{issueType}"
|
||||
msgstr ""
|
||||
|
||||
msgid "Close %{noteable}"
|
||||
msgstr ""
|
||||
|
||||
msgid "Close %{tabname}"
|
||||
msgstr ""
|
||||
|
||||
|
@ -14898,6 +14907,9 @@ msgstr ""
|
|||
msgid "Filter by merge requests that are currently merged."
|
||||
msgstr ""
|
||||
|
||||
msgid "Filter by milestone"
|
||||
msgstr ""
|
||||
|
||||
msgid "Filter by milestone name"
|
||||
msgstr ""
|
||||
|
||||
|
@ -17109,6 +17121,12 @@ msgstr ""
|
|||
msgid "Header message"
|
||||
msgstr ""
|
||||
|
||||
msgid "HeaderAction|incident"
|
||||
msgstr ""
|
||||
|
||||
msgid "HeaderAction|issue"
|
||||
msgstr ""
|
||||
|
||||
msgid "Headers"
|
||||
msgstr ""
|
||||
|
||||
|
@ -19431,6 +19449,9 @@ msgstr ""
|
|||
msgid "IssueBoards|Switch board"
|
||||
msgstr ""
|
||||
|
||||
msgid "IssueList|created %{timeAgoString} by %{user}"
|
||||
msgstr ""
|
||||
|
||||
msgid "IssueTracker|Custom issue tracker"
|
||||
msgstr ""
|
||||
|
||||
|
@ -27968,6 +27989,9 @@ msgstr ""
|
|||
msgid "Promotion is not supported."
|
||||
msgstr ""
|
||||
|
||||
msgid "Promotions|Add %{link_start} description templates %{link_end} to help your contributors to communicate effectively!"
|
||||
msgstr ""
|
||||
|
||||
msgid "Promotions|Add Group Webhooks and GitLab Enterprise Edition."
|
||||
msgstr ""
|
||||
|
||||
|
@ -29145,6 +29169,9 @@ msgstr ""
|
|||
msgid "Reopen %{issueType}"
|
||||
msgstr ""
|
||||
|
||||
msgid "Reopen %{noteable}"
|
||||
msgstr ""
|
||||
|
||||
msgid "Reopen epic"
|
||||
msgstr ""
|
||||
|
||||
|
@ -31400,6 +31427,9 @@ msgstr ""
|
|||
msgid "Select assignee"
|
||||
msgstr ""
|
||||
|
||||
msgid "Select assignee(s)"
|
||||
msgstr ""
|
||||
|
||||
msgid "Select branch"
|
||||
msgstr ""
|
||||
|
||||
|
@ -35591,6 +35621,9 @@ msgstr ""
|
|||
msgid "This is your current session"
|
||||
msgstr ""
|
||||
|
||||
msgid "This issue is confidential and should only be visible to team members with at least Reporter access."
|
||||
msgstr ""
|
||||
|
||||
msgid "This issue is currently blocked by the following issues:"
|
||||
msgstr ""
|
||||
|
||||
|
@ -38451,6 +38484,9 @@ msgstr ""
|
|||
msgid "View merge request"
|
||||
msgstr ""
|
||||
|
||||
msgid "View milestones"
|
||||
msgstr ""
|
||||
|
||||
msgid "View on %{url}"
|
||||
msgstr ""
|
||||
|
||||
|
|
|
@ -13,6 +13,10 @@ RSpec.describe Gitlab::Tracking do
|
|||
described_class.instance_variable_set("@snowplow", nil)
|
||||
end
|
||||
|
||||
after do
|
||||
described_class.instance_variable_set("@snowplow", nil)
|
||||
end
|
||||
|
||||
describe '.options' do
|
||||
shared_examples 'delegates to destination' do |klass|
|
||||
before do
|
||||
|
|
Loading…
Reference in New Issue