Commit 4ff2e1c4 authored by Doug Stull's avatar Doug Stull

Remove suggest pipeline feature flag

- feature is fully rolled out and validated.
parent 7ed55907
...@@ -73,7 +73,6 @@ document.addEventListener('DOMContentLoaded', () => { ...@@ -73,7 +73,6 @@ document.addEventListener('DOMContentLoaded', () => {
); );
} }
if (gon.features?.suggestPipeline) {
const successPipelineEl = document.querySelector('.js-success-pipeline-modal'); const successPipelineEl = document.querySelector('.js-success-pipeline-modal');
if (successPipelineEl) { if (successPipelineEl) {
...@@ -89,7 +88,6 @@ document.addEventListener('DOMContentLoaded', () => { ...@@ -89,7 +88,6 @@ document.addEventListener('DOMContentLoaded', () => {
}, },
}); });
} }
}
if (gon?.features?.gitlabCiYmlPreview) { if (gon?.features?.gitlabCiYmlPreview) {
createGitlabCiYmlVisualization(); createGitlabCiYmlVisualization();
......
...@@ -155,10 +155,7 @@ export default { ...@@ -155,10 +155,7 @@ export default {
}, },
shouldSuggestPipelines() { shouldSuggestPipelines() {
return ( return (
gon.features?.suggestPipeline && !this.mr.hasCI && this.mr.mergeRequestAddCiConfigPath && !this.mr.isDismissedSuggestPipeline
!this.mr.hasCI &&
this.mr.mergeRequestAddCiConfigPath &&
!this.mr.isDismissedSuggestPipeline
); );
}, },
shouldRenderCodeQuality() { shouldRenderCodeQuality() {
......
...@@ -33,7 +33,6 @@ class Projects::BlobController < Projects::ApplicationController ...@@ -33,7 +33,6 @@ class Projects::BlobController < Projects::ApplicationController
before_action :set_last_commit_sha, only: [:edit, :update] before_action :set_last_commit_sha, only: [:edit, :update]
before_action only: :show do before_action only: :show do
push_frontend_feature_flag(:suggest_pipeline, default_enabled: true)
push_frontend_feature_flag(:gitlab_ci_yml_preview, @project, default_enabled: false) push_frontend_feature_flag(:gitlab_ci_yml_preview, @project, default_enabled: false)
end end
......
...@@ -27,7 +27,6 @@ class Projects::MergeRequestsController < Projects::MergeRequests::ApplicationCo ...@@ -27,7 +27,6 @@ class Projects::MergeRequestsController < Projects::MergeRequests::ApplicationCo
before_action :authenticate_user!, only: [:assign_related_issues] before_action :authenticate_user!, only: [:assign_related_issues]
before_action :check_user_can_push_to_source_branch!, only: [:rebase] before_action :check_user_can_push_to_source_branch!, only: [:rebase]
before_action only: [:show] do before_action only: [:show] do
push_frontend_feature_flag(:suggest_pipeline, default_enabled: true)
push_frontend_feature_flag(:widget_visibility_polling, @project, default_enabled: true) push_frontend_feature_flag(:widget_visibility_polling, @project, default_enabled: true)
push_frontend_feature_flag(:mr_commit_neighbor_nav, @project, default_enabled: true) push_frontend_feature_flag(:mr_commit_neighbor_nav, @project, default_enabled: true)
push_frontend_feature_flag(:multiline_comments, @project, default_enabled: true) push_frontend_feature_flag(:multiline_comments, @project, default_enabled: true)
......
...@@ -382,7 +382,6 @@ module BlobHelper ...@@ -382,7 +382,6 @@ module BlobHelper
end end
def show_suggest_pipeline_creation_celebration? def show_suggest_pipeline_creation_celebration?
Feature.enabled?(:suggest_pipeline, default_enabled: true) &&
@blob.path == Gitlab::FileDetector::PATTERNS[:gitlab_ci] && @blob.path == Gitlab::FileDetector::PATTERNS[:gitlab_ci] &&
@blob.auxiliary_viewer&.valid?(project: @project, sha: @commit.sha, user: current_user) && @blob.auxiliary_viewer&.valid?(project: @project, sha: @commit.sha, user: current_user) &&
@project.uses_default_ci_config? && @project.uses_default_ci_config? &&
......
...@@ -2,8 +2,6 @@ ...@@ -2,8 +2,6 @@
module SuggestPipelineHelper module SuggestPipelineHelper
def should_suggest_gitlab_ci_yml? def should_suggest_gitlab_ci_yml?
Feature.enabled?(:suggest_pipeline, default_enabled: true) && current_user && params[:suggest_gitlab_ci_yml] == 'true'
current_user &&
params[:suggest_gitlab_ci_yml] == 'true'
end end
end end
...@@ -67,15 +67,15 @@ class MergeRequestWidgetEntity < Grape::Entity ...@@ -67,15 +67,15 @@ class MergeRequestWidgetEntity < Grape::Entity
) )
end end
expose :user_callouts_path, if: -> (*) { Feature.enabled?(:suggest_pipeline, default_enabled: true) } do |_merge_request| expose :user_callouts_path do |_merge_request|
user_callouts_path user_callouts_path
end end
expose :suggest_pipeline_feature_id, if: -> (*) { Feature.enabled?(:suggest_pipeline, default_enabled: true) } do |_merge_request| expose :suggest_pipeline_feature_id do |_merge_request|
SUGGEST_PIPELINE SUGGEST_PIPELINE
end end
expose :is_dismissed_suggest_pipeline, if: -> (*) { Feature.enabled?(:suggest_pipeline, default_enabled: true) } do |_merge_request| expose :is_dismissed_suggest_pipeline do |_merge_request|
current_user && current_user.dismissed_callout?(feature_name: SUGGEST_PIPELINE) current_user && current_user.dismissed_callout?(feature_name: SUGGEST_PIPELINE)
end end
......
---
name: suggest_pipeline
introduced_by_url: https://gitlab.com/gitlab-org/gitlab/-/merge_requests/45926
rollout_issue_url: https://gitlab.com/gitlab-org/gitlab/-/issues/267492
milestone: '13.6'
type: development
group: group::expansion
default_enabled: true
...@@ -849,7 +849,7 @@ describe('mrWidgetOptions', () => { ...@@ -849,7 +849,7 @@ describe('mrWidgetOptions', () => {
}); });
}); });
describe('suggestPipeline feature flag', () => { describe('suggestPipeline', () => {
beforeEach(() => { beforeEach(() => {
mock.onAny().reply(200); mock.onAny().reply(200);
...@@ -860,8 +860,6 @@ describe('mrWidgetOptions', () => { ...@@ -860,8 +860,6 @@ describe('mrWidgetOptions', () => {
describe('given feature flag is enabled', () => { describe('given feature flag is enabled', () => {
beforeEach(() => { beforeEach(() => {
gon.features = { suggestPipeline: true };
createComponent(); createComponent();
vm.mr.hasCI = false; vm.mr.hasCI = false;
...@@ -891,19 +889,5 @@ describe('mrWidgetOptions', () => { ...@@ -891,19 +889,5 @@ describe('mrWidgetOptions', () => {
expect(findSuggestPipeline()).toBeNull(); expect(findSuggestPipeline()).toBeNull();
}); });
}); });
describe('given feature flag is not enabled', () => {
beforeEach(() => {
gon.features = { suggestPipeline: false };
createComponent();
vm.mr.hasCI = false;
});
it('should not suggest pipelines when none exist', () => {
expect(findSuggestPipeline()).toBeNull();
});
});
}); });
}); });
...@@ -236,7 +236,6 @@ RSpec.describe BlobHelper do ...@@ -236,7 +236,6 @@ RSpec.describe BlobHelper do
let(:data) { File.read(Rails.root.join('spec/support/gitlab_stubs/gitlab_ci.yml')) } let(:data) { File.read(Rails.root.join('spec/support/gitlab_stubs/gitlab_ci.yml')) }
let(:blob) { fake_blob(path: Gitlab::FileDetector::PATTERNS[:gitlab_ci], data: data) } let(:blob) { fake_blob(path: Gitlab::FileDetector::PATTERNS[:gitlab_ci], data: data) }
context 'feature enabled' do
it 'is true' do it 'is true' do
expect(helper.show_suggest_pipeline_creation_celebration?).to be_truthy expect(helper.show_suggest_pipeline_creation_celebration?).to be_truthy
end end
...@@ -280,28 +279,15 @@ RSpec.describe BlobHelper do ...@@ -280,28 +279,15 @@ RSpec.describe BlobHelper do
end end
end end
context 'feature disabled' do
before do
stub_feature_flags(suggest_pipeline: false)
end
it 'is false' do
expect(helper.show_suggest_pipeline_creation_celebration?).to be_falsey
end
end
end
context 'when file is not a pipeline config file' do context 'when file is not a pipeline config file' do
let(:blob) { fake_blob(path: 'LICENSE') } let(:blob) { fake_blob(path: 'LICENSE') }
context 'feature enabled' do
it 'is false' do it 'is false' do
expect(helper.show_suggest_pipeline_creation_celebration?).to be_falsey expect(helper.show_suggest_pipeline_creation_celebration?).to be_falsey
end end
end end
end end
end end
end
describe 'suggest_pipeline_commit_cookie_name' do describe 'suggest_pipeline_commit_cookie_name' do
let(:project) { create(:project) } let(:project) { create(:project) }
......
...@@ -285,8 +285,7 @@ RSpec.describe MergeRequestWidgetEntity do ...@@ -285,8 +285,7 @@ RSpec.describe MergeRequestWidgetEntity do
end end
describe 'user callouts' do describe 'user callouts' do
context 'when suggest pipeline feature is enabled' do subject { described_class.new(resource, request: request).as_json }
subject { described_class.new(resource, request: request, experiment_enabled: :suggest_pipeline).as_json }
it 'provides a valid path value for user callout path' do it 'provides a valid path value for user callout path' do
expect(subject[:user_callouts_path]).to eq '/-/user_callouts' expect(subject[:user_callouts_path]).to eq '/-/user_callouts'
...@@ -319,25 +318,6 @@ RSpec.describe MergeRequestWidgetEntity do ...@@ -319,25 +318,6 @@ RSpec.describe MergeRequestWidgetEntity do
end end
end end
context 'when suggest pipeline feature is not enabled' do
before do
stub_feature_flags(suggest_pipeline: false)
end
it 'provides no valid value for user callout path' do
expect(subject[:user_callouts_path]).to be_nil
end
it 'provides no valid value for suggest pipeline feature id' do
expect(subject[:suggest_pipeline_feature_id]).to be_nil
end
it 'provides no valid value for if it is dismissed' do
expect(subject[:is_dismissed_suggest_pipeline]).to be_nil
end
end
end
it 'has human access' do it 'has human access' do
project.add_maintainer(user) project.add_maintainer(user)
......
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