Commit 01c2af91 authored by Patrick Bajao's avatar Patrick Bajao

Merge branch 'remove-merge-request-count-with-merged-at-ff' into 'master'

Remove merge request merged at count FF [RUN ALL RSPEC] [RUN AS-IF-FOSS]

See merge request gitlab-org/gitlab!55600
parents 02fcb882 1f099b6a
...@@ -10,7 +10,7 @@ module Resolvers ...@@ -10,7 +10,7 @@ module Resolvers
def resolve(**args) def resolve(**args)
scope = super scope = super
if only_count_is_selected_with_merged_at_filter?(args) && Feature.enabled?(:optimized_merge_request_count_with_merged_at_filter, default_enabled: :yaml) if only_count_is_selected_with_merged_at_filter?(args)
MergeRequest::MetricsFinder MergeRequest::MetricsFinder
.new(current_user, args.merge(target_project: project)) .new(current_user, args.merge(target_project: project))
.execute .execute
......
---
title: Remove the optimized_merge_request_count_with_merged_at_filter feature flag
merge_request: 55600
author:
type: other
---
name: optimized_merge_request_count_with_merged_at_filter
introduced_by_url: https://gitlab.com/gitlab-org/gitlab/-/merge_requests/52113
rollout_issue_url: https://gitlab.com/gitlab-org/gitlab/-/issues/299347
milestone: '13.9'
type: development
group: group::optimize
default_enabled: true
...@@ -427,63 +427,37 @@ RSpec.describe 'getting merge request listings nested in a project' do ...@@ -427,63 +427,37 @@ RSpec.describe 'getting merge request listings nested in a project' do
QUERY QUERY
end end
shared_examples 'count examples' do it 'does not query the merge requests table for the count' do
it 'returns the correct count' do query_recorder = ActiveRecord::QueryRecorder.new { post_graphql(query, current_user: current_user) }
post_graphql(query, current_user: current_user)
count = graphql_data.dig('project', 'mergeRequests', 'count') queries = query_recorder.data.each_value.first[:occurrences]
expect(count).to eq(1) expect(queries).not_to include(match(/SELECT COUNT\(\*\) FROM "merge_requests"/))
end expect(queries).to include(match(/SELECT COUNT\(\*\) FROM "merge_request_metrics"/))
end end
context 'when "optimized_merge_request_count_with_merged_at_filter" feature flag is enabled' do context 'when total_time_to_merge and count is queried' do
before do let(:query) do
stub_feature_flags(optimized_merge_request_count_with_merged_at_filter: true) graphql_query_for(:project, { full_path: project.full_path }, <<~QUERY)
mergeRequests(mergedAfter: "2020-01-01", mergedBefore: "2020-01-05", first: 0) {
totalTimeToMerge
count
}
QUERY
end end
it 'does not query the merge requests table for the count' do it 'does not query the merge requests table for the total_time_to_merge' do
query_recorder = ActiveRecord::QueryRecorder.new { post_graphql(query, current_user: current_user) } query_recorder = ActiveRecord::QueryRecorder.new { post_graphql(query, current_user: current_user) }
queries = query_recorder.data.each_value.first[:occurrences] queries = query_recorder.data.each_value.first[:occurrences]
expect(queries).not_to include(match(/SELECT COUNT\(\*\) FROM "merge_requests"/)) expect(queries).to include(match(/SELECT.+SUM.+FROM "merge_request_metrics" WHERE/))
expect(queries).to include(match(/SELECT COUNT\(\*\) FROM "merge_request_metrics"/))
end
context 'when total_time_to_merge and count is queried' do
let(:query) do
graphql_query_for(:project, { full_path: project.full_path }, <<~QUERY)
mergeRequests(mergedAfter: "2020-01-01", mergedBefore: "2020-01-05", first: 0) {
totalTimeToMerge
count
}
QUERY
end
it 'does not query the merge requests table for the total_time_to_merge' do
query_recorder = ActiveRecord::QueryRecorder.new { post_graphql(query, current_user: current_user) }
queries = query_recorder.data.each_value.first[:occurrences]
expect(queries).to include(match(/SELECT.+SUM.+FROM "merge_request_metrics" WHERE/))
end
end end
end
it_behaves_like 'count examples' it 'returns the correct count' do
post_graphql(query, current_user: current_user)
context 'when "optimized_merge_request_count_with_merged_at_filter" feature flag is disabled' do
before do
stub_feature_flags(optimized_merge_request_count_with_merged_at_filter: false)
end
it 'queries the merge requests table for the count' do
query_recorder = ActiveRecord::QueryRecorder.new { post_graphql(query, current_user: current_user) }
queries = query_recorder.data.each_value.first[:occurrences]
expect(queries).to include(match(/SELECT COUNT\(\*\) FROM "merge_requests"/))
expect(queries).not_to include(match(/SELECT COUNT\(\*\) FROM "merge_request_metrics"/))
end
it_behaves_like 'count examples' count = graphql_data.dig('project', 'mergeRequests', 'count')
end expect(count).to eq(1)
end 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