Commit f9f6f513 authored by Robert Hunt's avatar Robert Hunt

Add license check to status checks rendering

Adds a license check to status checks to make sure it only renders
when the customer has the license feature now the feature flag is being
rolled out

Changelog: fixed
MR: https://gitlab.com/gitlab-org/gitlab/-/merge_requests/65246
EE: true
parent 6e48a8e0
......@@ -8,7 +8,7 @@
= render_ce 'projects/merge_request_merge_checks_settings', project: @project, form: form
- if ::Feature.enabled?(:ff_external_status_checks, @project, default_enabled: :yaml)
- if ::Feature.enabled?(:ff_external_status_checks, @project, default_enabled: :yaml) && @project.licensed_feature_available?(:external_status_checks)
= render_if_exists 'projects/merge_request_status_checks_settings'
= render 'projects/merge_request_merge_suggestions_settings', project: @project, form: form
......@@ -22,8 +22,8 @@
%p.text-secondary
= s_('ProjectSettings|Used for every new merge request.')
- create_a_merge_request_template_help_link_url = help_page_path('user/project/description_templates', anchor: 'create-a-merge-request-template')
- create_a_merge_request_templates_elp_link_start = '<a href="%{url}" target="_blank" rel="noopener noreferrer">'.html_safe % { url: create_a_merge_request_template_help_link_url }
= s_('ProjectSettings|%{link_start}What are description templates?%{link_end}').html_safe % { link_start: create_a_merge_request_templates_elp_link_start, link_end: '</a>'.html_safe }
- create_a_merge_request_templates_help_link_start = '<a href="%{url}" target="_blank" rel="noopener noreferrer">'.html_safe % { url: create_a_merge_request_template_help_link_url }
= s_('ProjectSettings|%{link_start}What are description templates?%{link_end}').html_safe % { link_start: create_a_merge_request_templates_help_link_start, link_end: '</a>'.html_safe }
= form.text_area :merge_requests_template, class: "form-control", rows: 3, data: { qa_selector: 'default_merge_request_template_field' }
......
......@@ -17,6 +17,21 @@ RSpec.describe 'Project settings > [EE] Merge Requests', :js do
end
context 'Status checks' do
context 'Feature flag is disabled' do
before do
stub_feature_flags(ff_external_status_checks: false)
end
it 'does not render the status checks area' do
expect(page).not_to have_selector('[data-testid="status-checks-table"]')
end
end
context 'Feature flag is enabled' do
before do
stub_feature_flags(ff_external_status_checks: true)
end
context 'Feature is not available' do
before do
stub_licensed_features(external_status_checks: false)
......@@ -92,6 +107,7 @@ RSpec.describe 'Project settings > [EE] Merge Requests', :js do
end
end
end
end
context 'Issuable default templates' do
context 'Feature is not available' do
......
......@@ -16,21 +16,26 @@ RSpec.describe 'projects/edit' do
end
context 'status checks' do
context 'feature enabled' do
context 'feature flag is disabled' do
before do
stub_feature_flags(ff_external_status_checks: true)
stub_feature_flags(ff_external_status_checks: false)
render
end
it 'shows the status checks area' do
expect(rendered).to have_content('Status check')
it 'hides the status checks area' do
expect(rendered).not_to have_content('Status check')
end
end
context 'feature disabled' do
context 'feature flag is enabled' do
before do
stub_feature_flags(ff_external_status_checks: false)
stub_feature_flags(ff_external_status_checks: true)
end
context 'feature is not available' do
before do
stub_licensed_features(external_status_checks: false)
render
end
......@@ -39,5 +44,18 @@ RSpec.describe 'projects/edit' do
expect(rendered).not_to have_content('Status check')
end
end
context 'feature is available' do
before do
stub_licensed_features(external_status_checks: true)
render
end
it 'shows the status checks area' do
expect(rendered).to have_content('Status check')
end
end
end
end
end
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