Commit 77d12c4a authored by Doug Stull's avatar Doug Stull Committed by Jan Provaznik

Add permission check to pipeline tour

- only initiate the tour entry point
  based on if this feature exists and if
  user has proper permissions.
parent 983f665d
...@@ -94,6 +94,8 @@ class MergeRequestWidgetEntity < Grape::Entity ...@@ -94,6 +94,8 @@ class MergeRequestWidgetEntity < Grape::Entity
merge_request.source_project&.uses_default_ci_config? && merge_request.source_project&.uses_default_ci_config? &&
merge_request.all_pipelines.none? && merge_request.all_pipelines.none? &&
merge_request.commits_count.positive? && merge_request.commits_count.positive? &&
can?(current_user, :read_build, merge_request.source_project) &&
can?(current_user, :create_pipeline, merge_request.source_project) &&
can?(current_user, :push_code, merge_request.source_project) can?(current_user, :push_code, merge_request.source_project)
end end
end end
......
...@@ -123,6 +123,16 @@ describe MergeRequestWidgetEntity do ...@@ -123,6 +123,16 @@ describe MergeRequestWidgetEntity do
expect(subject[:merge_request_add_ci_config_path]).not_to be_nil expect(subject[:merge_request_add_ci_config_path]).not_to be_nil
end end
end end
context 'when feature is disabled' do
before do
project.project_feature.update(repository_access_level: ProjectFeature::DISABLED)
end
it 'has no path' do
expect(subject[:merge_request_add_ci_config_path]).to be_nil
end
end
end end
context 'when user does not have permissions' do context 'when user does not have permissions' do
......
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