Commit eeda9e91 authored by Markus Koller's avatar Markus Koller

Merge branch 'tomquirk/326339-dont-repeat-optional-github-integration-form' into 'master'

Add custom label GitHub status check checkbox

See merge request gitlab-org/gitlab!72566
parents 1222dd09 6f0368ec
...@@ -62,6 +62,14 @@ export default { ...@@ -62,6 +62,14 @@ export default {
required: false, required: false,
default: null, default: null,
}, },
/**
* The label that is displayed inline with the checkbox.
*/
checkboxLabel: {
type: String,
required: false,
default: null,
},
}, },
data() { data() {
return { return {
...@@ -152,7 +160,7 @@ export default { ...@@ -152,7 +160,7 @@ export default {
<template v-if="isCheckbox"> <template v-if="isCheckbox">
<input :name="fieldName" type="hidden" :value="model || false" /> <input :name="fieldName" type="hidden" :value="model || false" />
<gl-form-checkbox :id="fieldId" v-model="model" :disabled="isInheriting"> <gl-form-checkbox :id="fieldId" v-model="model" :disabled="isInheriting">
{{ humanizedTitle }} {{ checkboxLabel || humanizedTitle }}
</gl-form-checkbox> </gl-form-checkbox>
</template> </template>
<template v-else-if="isSelect"> <template v-else-if="isSelect">
......
...@@ -4,7 +4,7 @@ class ServiceFieldEntity < Grape::Entity ...@@ -4,7 +4,7 @@ class ServiceFieldEntity < Grape::Entity
include RequestAwareEntity include RequestAwareEntity
include Gitlab::Utils::StrongMemoize include Gitlab::Utils::StrongMemoize
expose :type, :name, :placeholder, :required, :choices expose :type, :name, :placeholder, :required, :choices, :checkbox_label
expose :title do |field| expose :title do |field|
non_empty_password?(field) ? field[:non_empty_password_title] : field[:title] non_empty_password?(field) ? field[:non_empty_password_title] : field[:title]
......
...@@ -740,7 +740,7 @@ Parameters: ...@@ -740,7 +740,7 @@ Parameters:
| --------- | ---- | -------- | ----------- | | --------- | ---- | -------- | ----------- |
| `token` | string | true | GitHub API token with `repo:status` OAuth scope | | `token` | string | true | GitHub API token with `repo:status` OAuth scope |
| `repository_url` | string | true | GitHub repository URL | | `repository_url` | string | true | GitHub repository URL |
| `static_context` | boolean | false | Append instance name instead of branch to [status check name](../user/project/integrations/github.md#static--dynamic-status-check-names) | | `static_context` | boolean | false | Append instance name instead of branch to [status check name](../user/project/integrations/github.md#static-or-dynamic-status-check-names) |
### Disable GitHub integration ### Disable GitHub integration
......
...@@ -37,20 +37,20 @@ Complete these steps in GitLab: ...@@ -37,20 +37,20 @@ Complete these steps in GitLab:
1. Ensure that the **Active** toggle is enabled. 1. Ensure that the **Active** toggle is enabled.
1. Paste the token you generated on GitHub. 1. Paste the token you generated on GitHub.
1. Enter the path to your project on GitHub, such as `https://github.com/username/repository`. 1. Enter the path to your project on GitHub, such as `https://github.com/username/repository`.
1. (Optional) To disable static status check names, clear the **Static status check names** checkbox. 1. (Optional) To disable static status check names, clear the **Enable static status check names** checkbox.
1. Select **Save changes** or optionally select **Test settings**. 1. Select **Save changes** or optionally select **Test settings**.
After configuring the integration, see [Pipelines for external pull requests](../../../ci/ci_cd_for_external_repos/#pipelines-for-external-pull-requests) After configuring the integration, see [Pipelines for external pull requests](../../../ci/ci_cd_for_external_repos/#pipelines-for-external-pull-requests)
to configure pipelines to run for open pull requests. to configure pipelines to run for open pull requests.
### Static / dynamic status check names ### Static or dynamic status check names
> - Introduced in GitLab 11.5: using static status check names as opt-in option. > - Introduced in GitLab 11.5: using static status check names as opt-in option.
> - [In GitLab 12.4](https://gitlab.com/gitlab-org/gitlab/-/issues/9931), static status check names is default behavior for new projects. > - [In GitLab 12.4](https://gitlab.com/gitlab-org/gitlab/-/issues/9931), static status check names is default behavior for new projects.
This makes it possible to mark these status checks as **Required** on GitHub. This makes it possible to mark these status checks as **Required** on GitHub.
When **Static status check names** is enabled on the integration page, your When **Enable static status check names** is checked on the integration page, your
GitLab instance host name is appended to a status check name. GitLab instance host name is appended to a status check name.
When disabled, it uses dynamic status check names and appends the branch name. When unchecked, it uses dynamic status check names and appends the branch name.
...@@ -39,7 +39,7 @@ module Integrations ...@@ -39,7 +39,7 @@ module Integrations
end end
def fields def fields
learn_more_link_url = help_page_path('user/project/integrations/github', anchor: 'static--dynamic-status-check-name') learn_more_link_url = help_page_path('user/project/integrations/github', anchor: 'static-or-dynamic-status-check-names')
learn_more_link_start = '<a href="%{url}" target="_blank" rel="noopener noreferrer">'.html_safe % { url: learn_more_link_url } learn_more_link_start = '<a href="%{url}" target="_blank" rel="noopener noreferrer">'.html_safe % { url: learn_more_link_url }
static_context_field_help = s_('GithubIntegration|Select this if you want GitHub to mark status checks as "Required". %{learn_more_link_start}Learn more%{learn_more_link_end}.').html_safe % { learn_more_link_start: learn_more_link_start, learn_more_link_end: '</a>'.html_safe } static_context_field_help = s_('GithubIntegration|Select this if you want GitHub to mark status checks as "Required". %{learn_more_link_start}Learn more%{learn_more_link_end}.').html_safe % { learn_more_link_start: learn_more_link_start, learn_more_link_end: '</a>'.html_safe }
...@@ -60,6 +60,7 @@ module Integrations ...@@ -60,6 +60,7 @@ module Integrations
{ type: 'checkbox', { type: 'checkbox',
name: "static_context", name: "static_context",
title: s_('GithubIntegration|Static status check names (optional)'), title: s_('GithubIntegration|Static status check names (optional)'),
checkbox_label: s_('GithubIntegration|Enable static status check names'),
help: static_context_field_help } help: static_context_field_help }
] ]
end end
......
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe ServiceFieldEntity do
let(:request) { double('request') }
subject { described_class.new(field, request: request, service: integration).as_json }
before do
allow(request).to receive(:service).and_return(integration)
end
describe '#as_json' do
context 'GitHub Service' do
let(:integration) { create(:github_integration) }
context 'field with type checkbox' do
let(:field) { integration_field('static_context') }
it 'exposes correct attributes and casts value to Boolean' do
expected_hash = {
type: 'checkbox',
name: 'static_context',
title: 'Static status check names (optional)',
placeholder: nil,
required: nil,
choices: nil,
value: 'true',
checkbox_label: 'Enable static status check names'
}
is_expected.to include(expected_hash)
end
end
end
end
def integration_field(name)
integration.global_fields.find { |f| f[:name] == name }
end
end
...@@ -15738,6 +15738,9 @@ msgstr "" ...@@ -15738,6 +15738,9 @@ msgstr ""
msgid "GithubIntegration|Create a %{token_link_start}personal access token%{token_link_end} with %{status_html} access granted and paste it here." msgid "GithubIntegration|Create a %{token_link_start}personal access token%{token_link_end} with %{status_html} access granted and paste it here."
msgstr "" msgstr ""
msgid "GithubIntegration|Enable static status check names"
msgstr ""
msgid "GithubIntegration|Obtain statuses for commits and pull requests." msgid "GithubIntegration|Obtain statuses for commits and pull requests."
msgstr "" msgstr ""
......
...@@ -35,15 +35,19 @@ describe('DynamicField', () => { ...@@ -35,15 +35,19 @@ describe('DynamicField', () => {
const findGlFormTextarea = () => wrapper.findComponent(GlFormTextarea); const findGlFormTextarea = () => wrapper.findComponent(GlFormTextarea);
describe('template', () => { describe('template', () => {
describe.each([ describe.each`
[true, 'disabled', 'readonly'], isInheriting | disabled | readonly | checkboxLabel
[false, undefined, undefined], ${true} | ${'disabled'} | ${'readonly'} | ${undefined}
])('dynamic field, when isInheriting = `%p`', (isInheriting, disabled, readonly) => { ${false} | ${undefined} | ${undefined} | ${'Custom checkbox label'}
`(
'dynamic field, when isInheriting = `%p`',
({ isInheriting, disabled, readonly, checkboxLabel }) => {
describe('type is checkbox', () => { describe('type is checkbox', () => {
beforeEach(() => { beforeEach(() => {
createComponent( createComponent(
{ {
type: 'checkbox', type: 'checkbox',
checkboxLabel,
}, },
isInheriting, isInheriting,
); );
...@@ -56,6 +60,10 @@ describe('DynamicField', () => { ...@@ -56,6 +60,10 @@ describe('DynamicField', () => {
); );
}); });
it(`renders GlFormCheckbox with correct text content when checkboxLabel is ${checkboxLabel}`, () => {
expect(findGlFormCheckbox().text()).toBe(checkboxLabel ?? defaultProps.title);
});
it('does not render other types of input', () => { it('does not render other types of input', () => {
expect(findGlFormSelect().exists()).toBe(false); expect(findGlFormSelect().exists()).toBe(false);
expect(findGlFormTextarea().exists()).toBe(false); expect(findGlFormTextarea().exists()).toBe(false);
...@@ -164,7 +172,8 @@ describe('DynamicField', () => { ...@@ -164,7 +172,8 @@ describe('DynamicField', () => {
expect(findGlFormTextarea().exists()).toBe(false); expect(findGlFormTextarea().exists()).toBe(false);
}); });
}); });
}); },
);
describe('help text', () => { describe('help text', () => {
it('renders description with help text', () => { it('renders description with help text', () => {
......
...@@ -27,7 +27,8 @@ RSpec.describe ServiceFieldEntity do ...@@ -27,7 +27,8 @@ RSpec.describe ServiceFieldEntity do
help: 'Use a username for server version and an email for cloud version.', help: 'Use a username for server version and an email for cloud version.',
required: true, required: true,
choices: nil, choices: nil,
value: 'jira_username' value: 'jira_username',
checkbox_label: nil
} }
is_expected.to eq(expected_hash) is_expected.to eq(expected_hash)
...@@ -46,7 +47,8 @@ RSpec.describe ServiceFieldEntity do ...@@ -46,7 +47,8 @@ RSpec.describe ServiceFieldEntity do
help: 'Leave blank to use your current password or API token.', help: 'Leave blank to use your current password or API token.',
required: true, required: true,
choices: nil, choices: nil,
value: 'true' value: 'true',
checkbox_label: nil
} }
is_expected.to eq(expected_hash) is_expected.to eq(expected_hash)
...@@ -68,7 +70,8 @@ RSpec.describe ServiceFieldEntity do ...@@ -68,7 +70,8 @@ RSpec.describe ServiceFieldEntity do
placeholder: nil, placeholder: nil,
required: nil, required: nil,
choices: nil, choices: nil,
value: 'true' value: 'true',
checkbox_label: nil
} }
is_expected.to include(expected_hash) is_expected.to include(expected_hash)
...@@ -88,7 +91,8 @@ RSpec.describe ServiceFieldEntity do ...@@ -88,7 +91,8 @@ RSpec.describe ServiceFieldEntity do
required: nil, required: nil,
choices: [['All branches', 'all'], ['Default branch', 'default'], ['Protected branches', 'protected'], ['Default branch and protected branches', 'default_and_protected']], choices: [['All branches', 'all'], ['Default branch', 'default'], ['Protected branches', 'protected'], ['Default branch and protected branches', 'default_and_protected']],
help: nil, help: nil,
value: nil value: nil,
checkbox_label: nil
} }
is_expected.to eq(expected_hash) is_expected.to eq(expected_hash)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment