Commit 2652e3ef authored by Stan Hu's avatar Stan Hu

Merge branch '260327_do_not_use_recursive_project_lookup_for_personal_namespaces' into 'master'

Use simplified query for user namespace projects

See merge request gitlab-org/gitlab!45514
parents bf3c78e6 9902a915
...@@ -284,7 +284,8 @@ class Namespace < ApplicationRecord ...@@ -284,7 +284,8 @@ class Namespace < ApplicationRecord
# that belongs to this namespace # that belongs to this namespace
def all_projects def all_projects
if Feature.enabled?(:recursive_approach_for_all_projects) if Feature.enabled?(:recursive_approach_for_all_projects)
Project.where(namespace: self_and_descendants) namespace = user? ? self : self_and_descendants
Project.where(namespace: namespace)
else else
Project.inside_path(full_path) Project.inside_path(full_path)
end end
......
...@@ -623,6 +623,7 @@ RSpec.describe Namespace do ...@@ -623,6 +623,7 @@ RSpec.describe Namespace do
subject { namespace.any_project_with_shared_runners_enabled? } subject { namespace.any_project_with_shared_runners_enabled? }
context 'subgroup with shared runners enabled project' do context 'subgroup with shared runners enabled project' do
let(:namespace) { create(:group) }
let(:subgroup) { create(:group, parent: namespace) } let(:subgroup) { create(:group, parent: namespace) }
let!(:subproject) { create(:project, namespace: subgroup, shared_runners_enabled: true) } let!(:subproject) { create(:project, namespace: subgroup, shared_runners_enabled: true) }
......
...@@ -855,8 +855,8 @@ RSpec.describe Namespace do ...@@ -855,8 +855,8 @@ RSpec.describe Namespace do
end end
describe '#all_projects' do describe '#all_projects' do
shared_examples 'all projects for a namespace' do shared_examples 'all projects for a group' do
let(:namespace) { create(:namespace) } let(:namespace) { create(:group) }
let(:child) { create(:group, parent: namespace) } let(:child) { create(:group, parent: namespace) }
let!(:project1) { create(:project_empty_repo, namespace: namespace) } let!(:project1) { create(:project_empty_repo, namespace: namespace) }
let!(:project2) { create(:project_empty_repo, namespace: child) } let!(:project2) { create(:project_empty_repo, namespace: child) }
...@@ -865,30 +865,34 @@ RSpec.describe Namespace do ...@@ -865,30 +865,34 @@ RSpec.describe Namespace do
it { expect(child.all_projects.to_a).to match_array([project2]) } it { expect(child.all_projects.to_a).to match_array([project2]) }
end end
shared_examples 'all project examples' do shared_examples 'all projects for personal namespace' do
include_examples 'all projects for a namespace'
context 'when namespace is a group' do
let_it_be(:namespace) { create(:group) }
include_examples 'all projects for a namespace'
end
context 'when namespace is a user namespace' do
let_it_be(:user) { create(:user) } let_it_be(:user) { create(:user) }
let_it_be(:user_namespace) { create(:namespace, owner: user) } let_it_be(:user_namespace) { create(:namespace, owner: user) }
let_it_be(:project) { create(:project, namespace: user_namespace) } let_it_be(:project) { create(:project, namespace: user_namespace) }
it { expect(user_namespace.all_projects.to_a).to match_array([project]) } it { expect(user_namespace.all_projects.to_a).to match_array([project]) }
end end
end
context 'with recursive approach' do context 'with recursive approach' do
before do context 'when namespace is a group' do
stub_feature_flags(recursive_approach_for_all_projects: true) include_examples 'all projects for a group'
it 'queries for the namespace and its descendants' do
expect(Project).to receive(:where).with(namespace: [namespace, child])
namespace.all_projects
end
end end
include_examples 'all project examples' context 'when namespace is a user namespace' do
include_examples 'all projects for personal namespace'
it 'only queries for the namespace itself' do
expect(Project).to receive(:where).with(namespace: user_namespace)
user_namespace.all_projects
end
end
end end
context 'with route path wildcard approach' do context 'with route path wildcard approach' do
...@@ -896,7 +900,13 @@ RSpec.describe Namespace do ...@@ -896,7 +900,13 @@ RSpec.describe Namespace do
stub_feature_flags(recursive_approach_for_all_projects: false) stub_feature_flags(recursive_approach_for_all_projects: false)
end end
include_examples 'all project examples' context 'when namespace is a group' do
include_examples 'all projects for a group'
end
context 'when namespace is a user namespace' do
include_examples 'all projects for personal namespace'
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