Commit b47f6a62 authored by Adam Hegyi's avatar Adam Hegyi

Remove shared runners CTE FF

This change removes the
use_cte_for_any_project_with_shared_runners_enabled feature flag.

Changelog: removed
parent 3aebfb4a
---
name: use_cte_for_any_project_with_shared_runners_enabled
introduced_by_url: https://gitlab.com/gitlab-org/gitlab/-/merge_requests/71452
rollout_issue_url: https://gitlab.com/gitlab-org/gitlab/-/issues/342024
milestone: '14.4'
type: development
group: group::optimize
default_enabled: true
...@@ -430,22 +430,18 @@ module EE ...@@ -430,22 +430,18 @@ module EE
private private
def any_project_with_shared_runners_enabled_with_cte? def any_project_with_shared_runners_enabled_with_cte?
if ::Feature.enabled?(:use_cte_for_any_project_with_shared_runners_enabled, self, default_enabled: :yaml) projects_query = if user_namespace?
projects_query = if user_namespace? projects
projects else
else cte = ::Gitlab::SQL::CTE.new(:namespace_self_and_descendants_cte, self_and_descendant_ids)
cte = ::Gitlab::SQL::CTE.new(:namespace_self_and_descendants_cte, self_and_descendant_ids)
::Project
::Project .with(cte.to_arel)
.with(cte.to_arel) .from([::Project.table_name, cte.table.name].join(', '))
.from([::Project.table_name, cte.table.name].join(', ')) .where(::Project.arel_table[:namespace_id].eq(cte.table[:id]))
.where(::Project.arel_table[:namespace_id].eq(cte.table[:id])) end
end
projects_query.with_shared_runners.any?
projects_query.with_shared_runners.any?
else
all_projects.with_shared_runners.any?
end
end end
def fallback_plan def fallback_plan
......
...@@ -627,58 +627,32 @@ RSpec.describe Namespace do ...@@ -627,58 +627,32 @@ RSpec.describe Namespace do
describe '#any_project_with_shared_runners_enabled?' do describe '#any_project_with_shared_runners_enabled?' do
subject { namespace.any_project_with_shared_runners_enabled? } subject { namespace.any_project_with_shared_runners_enabled? }
shared_examples '#any_project_with_shared_runners_enabled? examples' do context 'without projects' do
context 'without projects' do it { is_expected.to be_falsey }
it { is_expected.to be_falsey }
end
context 'group with shared runners enabled project' do
let!(:project) { create(:project, namespace: namespace, shared_runners_enabled: true) }
it { is_expected.to be_truthy }
end
context 'subgroup with shared runners enabled project' do
let(:namespace) { create(:group) }
let(:subgroup) { create(:group, parent: namespace) }
let!(:subproject) { create(:project, namespace: subgroup, shared_runners_enabled: true) }
it { is_expected.to be_truthy }
end
context 'with project and disabled shared runners' do
let!(:project) do
create(:project,
namespace: namespace,
shared_runners_enabled: false)
end
it { is_expected.to be_falsey }
end
end end
context 'when use_cte_for_any_project_with_shared_runners_enabled is enabled' do context 'group with shared runners enabled project' do
before do let!(:project) { create(:project, namespace: namespace, shared_runners_enabled: true) }
stub_feature_flags(use_cte_for_any_project_with_shared_runners_enabled: true)
end
it_behaves_like '#any_project_with_shared_runners_enabled? examples' do it { is_expected.to be_truthy }
it 'creates a CTE' do end
group = create(:group)
expect(Gitlab::SQL::CTE).to receive(:new).and_call_original context 'subgroup with shared runners enabled project' do
let(:namespace) { create(:group) }
let(:subgroup) { create(:group, parent: namespace) }
let!(:subproject) { create(:project, namespace: subgroup, shared_runners_enabled: true) }
group.any_project_with_shared_runners_enabled? it { is_expected.to be_truthy }
end
end
end end
context 'when use_cte_for_any_project_with_shared_runners_enabled is disabled' do context 'with project and disabled shared runners' do
before do let!(:project) do
stub_feature_flags(use_cte_for_any_project_with_shared_runners_enabled: false) create(:project,
namespace: namespace,
shared_runners_enabled: false)
end end
it_behaves_like '#any_project_with_shared_runners_enabled? examples' it { is_expected.to be_falsey }
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