Commit 15c1c5be authored by Dylan Griffith's avatar Dylan Griffith

Merge branch '341114-fj-remove-runner-ancestors-scope' into 'master'

Enable Runner ancestor scopes

See merge request gitlab-org/gitlab!74991
parents b819e1f9 11d49cd2
...@@ -81,14 +81,7 @@ module Ci ...@@ -81,14 +81,7 @@ module Ci
scope :belonging_to_group, -> (group_id, include_ancestors: false) { scope :belonging_to_group, -> (group_id, include_ancestors: false) {
groups = ::Group.where(id: group_id) groups = ::Group.where(id: group_id)
groups = groups.self_and_ancestors if include_ancestors
if include_ancestors
groups = if Feature.enabled?(:linear_runner_ancestor_scopes, default_enabled: :yaml)
groups.self_and_ancestors
else
Gitlab::ObjectHierarchy.new(groups).base_and_ancestors
end
end
joins(:runner_namespaces) joins(:runner_namespaces)
.where(ci_runner_namespaces: { namespace_id: groups }) .where(ci_runner_namespaces: { namespace_id: groups })
...@@ -109,14 +102,9 @@ module Ci ...@@ -109,14 +102,9 @@ module Ci
scope :belonging_to_parent_group_of_project, -> (project_id) { scope :belonging_to_parent_group_of_project, -> (project_id) {
project_groups = ::Group.joins(:projects).where(projects: { id: project_id }) project_groups = ::Group.joins(:projects).where(projects: { id: project_id })
hierarchy_groups = if Feature.enabled?(:linear_runner_ancestor_scopes, default_enabled: :yaml)
project_groups.self_and_ancestors.as_ids
else
Gitlab::ObjectHierarchy.new(project_groups).base_and_ancestors
end
joins(:groups) joins(:groups)
.where(namespaces: { id: hierarchy_groups }) .where(namespaces: { id: project_groups.self_and_ancestors.as_ids })
.allow_cross_joins_across_databases(url: 'https://gitlab.com/gitlab-org/gitlab/-/issues/336433') .allow_cross_joins_across_databases(url: 'https://gitlab.com/gitlab-org/gitlab/-/issues/336433')
} }
......
---
name: linear_runner_ancestor_scopes
introduced_by_url: https://gitlab.com/gitlab-org/gitlab/-/merge_requests/70385
rollout_issue_url: https://gitlab.com/gitlab-org/gitlab/-/issues/341114
milestone: '14.6'
type: development
group: group::access
default_enabled: false
...@@ -204,7 +204,6 @@ RSpec.describe Ci::Runner do ...@@ -204,7 +204,6 @@ RSpec.describe Ci::Runner do
end end
describe '.belonging_to_parent_group_of_project' do describe '.belonging_to_parent_group_of_project' do
shared_examples 'returns parent group project runners' do
let(:project) { create(:project, group: group) } let(:project) { create(:project, group: group) }
let(:group) { create(:group) } let(:group) { create(:group) }
let(:runner) { create(:ci_runner, :group, groups: [group]) } let(:runner) { create(:ci_runner, :group, groups: [group]) }
...@@ -228,17 +227,6 @@ RSpec.describe Ci::Runner do ...@@ -228,17 +227,6 @@ RSpec.describe Ci::Runner do
end end
end end
it_behaves_like 'returns parent group project runners'
context 'when feature flag :linear_runner_ancestor_scopes is disabled' do
before do
stub_feature_flags(linear_runner_ancestor_scopes: false)
end
it_behaves_like 'returns parent group project runners'
end
end
describe '.owned_or_instance_wide' do describe '.owned_or_instance_wide' do
it 'returns a globally shared, a project specific and a group specific runner' do it 'returns a globally shared, a project specific and a group specific runner' do
# group specific # group specific
......
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