Commit 798885df authored by Shinya Maeda's avatar Shinya Maeda

Merge branch 'cache-action-compare-api' into 'master'

Add cache_action to repository compare [RUN ALL RSPEC] [RUN AS-IF-FOSS]

See merge request gitlab-org/gitlab!64407
parents f22913c3 bf799c95
---
name: api_caching_rate_limit_repository_compare
introduced_by_url: https://gitlab.com/gitlab-org/gitlab/-/merge_requests/64407
rollout_issue_url: https://gitlab.com/gitlab-org/gitlab/-/issues/334264
milestone: '14.1'
type: development
group: group::source code
default_enabled: false
...@@ -120,6 +120,9 @@ module API ...@@ -120,6 +120,9 @@ module API
optional :straight, type: Boolean, desc: 'Comparison method, `true` for direct comparison between `from` and `to` (`from`..`to`), `false` to compare using merge base (`from`...`to`)', default: false optional :straight, type: Boolean, desc: 'Comparison method, `true` for direct comparison between `from` and `to` (`from`..`to`), `false` to compare using merge base (`from`...`to`)', default: false
end end
get ':id/repository/compare' do get ':id/repository/compare' do
ff_enabled = Feature.enabled?(:api_caching_rate_limit_repository_compare, user_project, default_enabled: :yaml)
cache_action_if(ff_enabled, [user_project, :repository_compare, current_user, declared_params], expires_in: 30.seconds) do
if params[:from_project_id].present? if params[:from_project_id].present?
target_project = MergeRequestTargetProjectFinder target_project = MergeRequestTargetProjectFinder
.new(current_user: current_user, source_project: user_project, project_feature: :repository) .new(current_user: current_user, source_project: user_project, project_feature: :repository)
...@@ -140,6 +143,7 @@ module API ...@@ -140,6 +143,7 @@ module API
not_found!("Ref") not_found!("Ref")
end end
end end
end
desc 'Get repository contributors' do desc 'Get repository contributors' do
success Entities::Contributor success Entities::Contributor
......
...@@ -477,6 +477,17 @@ RSpec.describe API::Repositories do ...@@ -477,6 +477,17 @@ RSpec.describe API::Repositories do
let(:request) { get api(route, guest) } let(:request) { get api(route, guest) }
end end
end end
context 'api_caching_rate_limit_repository_compare is disabled' do
before do
stub_feature_flags(api_caching_rate_limit_repository_compare: false)
end
it_behaves_like 'repository compare' do
let(:project) { create(:project, :public, :repository) }
let(:current_user) { nil }
end
end
end end
describe 'GET /projects/:id/repository/contributors' do describe 'GET /projects/:id/repository/contributors' 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