Commit 98f7acc2 authored by Doug Stull's avatar Doug Stull

Merge branch '345786-fj-enable-groups-template-finder-ancestors-scopes' into 'master'

Use linear version GroupsWithTemplatesFinder#extended_group_search

See merge request gitlab-org/gitlab!75981
parents 87fe2564 5fe40a79
---
name: linear_groups_template_finder_extended_group_search_ancestors_scopes
introduced_by_url: https://gitlab.com/gitlab-org/gitlab/-/merge_requests/74599
rollout_issue_url: https://gitlab.com/gitlab-org/gitlab/-/issues/345786
milestone: '14.6'
type: development
group: group::access
default_enabled: false
...@@ -18,16 +18,11 @@ class GroupsWithTemplatesFinder ...@@ -18,16 +18,11 @@ class GroupsWithTemplatesFinder
attr_reader :group_id attr_reader :group_id
def extended_group_search def extended_group_search
# We're adding an extra query that will be removed once we remove the feature flag in https://gitlab.com/gitlab-org/gitlab/-/issues/339439 Group
groups = if Feature.enabled?(:linear_groups_template_finder_extended_group_search_ancestors_scopes, current_group, default_enabled: :yaml) .with_project_templates
Group.with_project_templates.self_and_ancestors .self_and_ancestors
else .with_feature_available_in_plan(:group_project_templates)
Gitlab::ObjectHierarchy .self_and_descendants
.new(Group.with_project_templates)
.base_and_ancestors
end
groups.with_feature_available_in_plan(:group_project_templates).self_and_descendants
end end
def simple_group_search(groups) def simple_group_search(groups)
...@@ -36,9 +31,4 @@ class GroupsWithTemplatesFinder ...@@ -36,9 +31,4 @@ class GroupsWithTemplatesFinder
groups.with_project_templates groups.with_project_templates
end end
# This method will be removed https://gitlab.com/gitlab-org/gitlab/-/issues/339439
def current_group
Group.find_by(id: group_id) # rubocop:disable CodeReuse/ActiveRecord
end
end end
...@@ -26,7 +26,6 @@ RSpec.describe GroupsWithTemplatesFinder, :saas do ...@@ -26,7 +26,6 @@ RSpec.describe GroupsWithTemplatesFinder, :saas do
create(:gitlab_subscription, :premium, namespace: group_2) create(:gitlab_subscription, :premium, namespace: group_2)
end end
shared_examples 'group template finder examples' do
describe 'without group id' do describe 'without group id' do
it 'returns all groups' do it 'returns all groups' do
expect(described_class.new.execute).to contain_exactly(group_1, group_2, group_3) expect(described_class.new.execute).to contain_exactly(group_1, group_2, group_3)
...@@ -34,7 +33,7 @@ RSpec.describe GroupsWithTemplatesFinder, :saas do ...@@ -34,7 +33,7 @@ RSpec.describe GroupsWithTemplatesFinder, :saas do
context 'when namespace checked' do context 'when namespace checked' do
before do before do
allow(Gitlab::CurrentSettings).to receive(:should_check_namespace_plan?) { true } stub_ee_application_setting(should_check_namespace_plan: true)
end end
it 'returns groups on ultimate/premium plan' do it 'returns groups on ultimate/premium plan' do
...@@ -72,7 +71,7 @@ RSpec.describe GroupsWithTemplatesFinder, :saas do ...@@ -72,7 +71,7 @@ RSpec.describe GroupsWithTemplatesFinder, :saas do
context 'when namespace checked' do context 'when namespace checked' do
before do before do
allow(Gitlab::CurrentSettings).to receive(:should_check_namespace_plan?) { true } stub_ee_application_setting(should_check_namespace_plan: true)
end end
it 'does not return the group' do it 'does not return the group' do
...@@ -95,15 +94,4 @@ RSpec.describe GroupsWithTemplatesFinder, :saas do ...@@ -95,15 +94,4 @@ RSpec.describe GroupsWithTemplatesFinder, :saas do
end end
end end
end end
end
it_behaves_like 'group template finder examples'
context 'when feature flag :linear_groups_template_finder_extended_group_search_ancestors_scopes is disabled' do
before do
stub_feature_flags(linear_groups_template_finder_extended_group_search_ancestors_scopes: false)
end
it_behaves_like 'group template finder examples'
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