Commit 04948056 authored by Alex Kalderimis's avatar Alex Kalderimis

Ensure we never use a blank group

This also improves the performance of the labels_finder_spec, by running
set-up only once, we go from 1m40s to 30sec run time.
parent b0f56e73
...@@ -46,7 +46,6 @@ class LabelsFinder < UnionFinder ...@@ -46,7 +46,6 @@ class LabelsFinder < UnionFinder
end end
else else
if group? if group?
group = params[:group] || Group.find(params[:group_id])
label_ids << Label.where(group_id: group_ids_for(group)) label_ids << Label.where(group_id: group_ids_for(group))
end end
...@@ -126,6 +125,10 @@ class LabelsFinder < UnionFinder ...@@ -126,6 +125,10 @@ class LabelsFinder < UnionFinder
params[:group].present? || params[:group_id].present? params[:group].present? || params[:group_id].present?
end end
def group
strong_memoize(:group) { params[:group].presence || Group.find(params[:group_id]) }
end
def project? def project?
params[:project].present? || params[:project_id].present? params[:project].present? || params[:project_id].present?
end end
...@@ -169,7 +172,7 @@ class LabelsFinder < UnionFinder ...@@ -169,7 +172,7 @@ class LabelsFinder < UnionFinder
ProjectsFinder.new(params: { non_archived: true }, current_user: current_user).execute # rubocop: disable CodeReuse/Finder ProjectsFinder.new(params: { non_archived: true }, current_user: current_user).execute # rubocop: disable CodeReuse/Finder
end end
@projects = @projects.in_namespace(params[:group_id]) if group? @projects = @projects.in_namespace(group.id) if group?
@projects = @projects.where(id: params[:project_ids]) if projects? @projects = @projects.where(id: params[:project_ids]) if projects?
@projects = @projects.reorder(nil) @projects = @projects.reorder(nil)
......
...@@ -4,35 +4,35 @@ require 'spec_helper' ...@@ -4,35 +4,35 @@ require 'spec_helper'
describe LabelsFinder do describe LabelsFinder do
describe '#execute' do describe '#execute' do
let(:group_1) { create(:group) } let_it_be(:group_1) { create(:group) }
let(:group_2) { create(:group) } let_it_be(:group_2) { create(:group) }
let(:group_3) { create(:group) } let_it_be(:group_3) { create(:group) }
let(:private_group_1) { create(:group, :private) } let_it_be(:private_group_1) { create(:group, :private) }
let(:private_subgroup_1) { create(:group, :private, parent: private_group_1) } let_it_be(:private_subgroup_1) { create(:group, :private, parent: private_group_1) }
let(:project_1) { create(:project, namespace: group_1) } let_it_be(:project_1, reload: true) { create(:project, namespace: group_1) }
let(:project_2) { create(:project, namespace: group_2) } let_it_be(:project_2) { create(:project, namespace: group_2) }
let(:project_3) { create(:project) } let_it_be(:project_3) { create(:project) }
let(:project_4) { create(:project, :public) } let_it_be(:project_4) { create(:project, :public) }
let(:project_5) { create(:project, namespace: group_1) } let_it_be(:project_5) { create(:project, namespace: group_1) }
let!(:project_label_1) { create(:label, project: project_1, title: 'Label 1', description: 'awesome label') } let_it_be(:project_label_1) { create(:label, project: project_1, title: 'Label 1', description: 'awesome label') }
let!(:project_label_2) { create(:label, project: project_2, title: 'Label 2') } let_it_be(:project_label_2) { create(:label, project: project_2, title: 'Label 2') }
let!(:project_label_4) { create(:label, project: project_4, title: 'Label 4') } let_it_be(:project_label_4) { create(:label, project: project_4, title: 'Label 4') }
let!(:project_label_5) { create(:label, project: project_5, title: 'Label 5') } let_it_be(:project_label_5) { create(:label, project: project_5, title: 'Label 5') }
let!(:group_label_1) { create(:group_label, group: group_1, title: 'Label 1 (group)') } let_it_be(:group_label_1) { create(:group_label, group: group_1, title: 'Label 1 (group)') }
let!(:group_label_2) { create(:group_label, group: group_1, title: 'Group Label 2') } let_it_be(:group_label_2) { create(:group_label, group: group_1, title: 'Group Label 2') }
let!(:group_label_3) { create(:group_label, group: group_2, title: 'Group Label 3') } let_it_be(:group_label_3) { create(:group_label, group: group_2, title: 'Group Label 3') }
let!(:private_group_label_1) { create(:group_label, group: private_group_1, title: 'Private Group Label 1') } let_it_be(:private_group_label_1) { create(:group_label, group: private_group_1, title: 'Private Group Label 1') }
let!(:private_subgroup_label_1) { create(:group_label, group: private_subgroup_1, title: 'Private Sub Group Label 1') } let_it_be(:private_subgroup_label_1) { create(:group_label, group: private_subgroup_1, title: 'Private Sub Group Label 1') }
let(:user) { create(:user) } let_it_be(:unused_label) { create(:label, project: project_3, title: 'Label 3') }
let_it_be(:unused_group_label) { create(:group_label, group: group_3, title: 'Group Label 4') }
let_it_be(:user) { create(:user) }
before do before do
create(:label, project: project_3, title: 'Label 3')
create(:group_label, group: group_3, title: 'Group Label 4')
project_1.add_developer(user) project_1.add_developer(user)
end end
...@@ -54,11 +54,11 @@ describe LabelsFinder do ...@@ -54,11 +54,11 @@ describe LabelsFinder do
end end
end end
context 'filtering by group_id' do shared_examples 'filtering by group' do
it 'returns labels available for any non-archived project within the group' do it 'returns labels available for any non-archived project within the group' do
group_1.add_developer(user) group_1.add_developer(user)
::Projects::UpdateService.new(project_1, user, archived: true).execute ::Projects::UpdateService.new(project_1, user, archived: true).execute
finder = described_class.new(user, group_id: group_1.id) finder = described_class.new(user, **group_params(group_1))
expect(finder.execute).to eq [group_label_2, group_label_1, project_label_5] expect(finder.execute).to eq [group_label_2, group_label_1, project_label_5]
end end
...@@ -67,7 +67,7 @@ describe LabelsFinder do ...@@ -67,7 +67,7 @@ describe LabelsFinder do
it 'returns only group labels' do it 'returns only group labels' do
group_1.add_developer(user) group_1.add_developer(user)
finder = described_class.new(user, group_id: group_1.id, only_group_labels: true) finder = described_class.new(user, only_group_labels: true, **group_params(group_1))
expect(finder.execute).to eq [group_label_2, group_label_1] expect(finder.execute).to eq [group_label_2, group_label_1]
end end
...@@ -84,7 +84,7 @@ describe LabelsFinder do ...@@ -84,7 +84,7 @@ describe LabelsFinder do
context 'when only group labels is false' do context 'when only group labels is false' do
it 'returns group labels' do it 'returns group labels' do
finder = described_class.new(user, group_id: empty_group.id) finder = described_class.new(user, **group_params(empty_group))
expect(finder.execute).to eq [empty_group_label_1, empty_group_label_2] expect(finder.execute).to eq [empty_group_label_1, empty_group_label_2]
end end
...@@ -96,7 +96,7 @@ describe LabelsFinder do ...@@ -96,7 +96,7 @@ describe LabelsFinder do
private_group_1.add_developer(user) private_group_1.add_developer(user)
private_subgroup_1.add_developer(user) private_subgroup_1.add_developer(user)
finder = described_class.new(user, group_id: private_subgroup_1.id, only_group_labels: true, include_ancestor_groups: true) finder = described_class.new(user, **group_params(private_subgroup_1), only_group_labels: true, include_ancestor_groups: true)
expect(finder.execute).to eq [private_group_label_1, private_subgroup_label_1] expect(finder.execute).to eq [private_group_label_1, private_subgroup_label_1]
end end
...@@ -104,7 +104,7 @@ describe LabelsFinder do ...@@ -104,7 +104,7 @@ describe LabelsFinder do
it 'ignores labels from groups which user can not read' do it 'ignores labels from groups which user can not read' do
private_subgroup_1.add_developer(user) private_subgroup_1.add_developer(user)
finder = described_class.new(user, group_id: private_subgroup_1.id, only_group_labels: true, include_ancestor_groups: true) finder = described_class.new(user, **group_params(private_subgroup_1), only_group_labels: true, include_ancestor_groups: true)
expect(finder.execute).to eq [private_subgroup_label_1] expect(finder.execute).to eq [private_subgroup_label_1]
end end
...@@ -115,7 +115,7 @@ describe LabelsFinder do ...@@ -115,7 +115,7 @@ describe LabelsFinder do
private_group_1.add_developer(user) private_group_1.add_developer(user)
private_subgroup_1.add_developer(user) private_subgroup_1.add_developer(user)
finder = described_class.new(user, group_id: private_group_1.id, only_group_labels: true, include_descendant_groups: true) finder = described_class.new(user, **group_params(private_group_1), only_group_labels: true, include_descendant_groups: true)
expect(finder.execute).to eq [private_group_label_1, private_subgroup_label_1] expect(finder.execute).to eq [private_group_label_1, private_subgroup_label_1]
end end
...@@ -123,14 +123,14 @@ describe LabelsFinder do ...@@ -123,14 +123,14 @@ describe LabelsFinder do
it 'ignores labels from groups which user can not read' do it 'ignores labels from groups which user can not read' do
private_subgroup_1.add_developer(user) private_subgroup_1.add_developer(user)
finder = described_class.new(user, group_id: private_group_1.id, only_group_labels: true, include_descendant_groups: true) finder = described_class.new(user, **group_params(private_group_1), only_group_labels: true, include_descendant_groups: true)
expect(finder.execute).to eq [private_subgroup_label_1] expect(finder.execute).to eq [private_subgroup_label_1]
end end
end end
context 'when including labels from group projects with limited visibility' do context 'when including labels from group projects with limited visibility' do
let(:finder) { described_class.new(user, group_id: group_4.id) } let(:finder) { described_class.new(user, **group_params(group_4)) }
let(:group_4) { create(:group) } let(:group_4) { create(:group) }
let(:limited_visibility_project) { create(:project, :public, group: group_4) } let(:limited_visibility_project) { create(:project, :public, group: group_4) }
let(:visible_project) { create(:project, :public, group: group_4) } let(:visible_project) { create(:project, :public, group: group_4) }
...@@ -213,6 +213,24 @@ describe LabelsFinder do ...@@ -213,6 +213,24 @@ describe LabelsFinder do
end end
end end
it_behaves_like 'filtering by group' do
def group_params(group)
{ group: group }
end
end
it_behaves_like 'filtering by group' do
def group_params(group)
{ group_id: group.id }
end
end
it_behaves_like 'filtering by group' do
def group_params(group)
{ group: '', group_id: group.id }
end
end
context 'filtering by project_id' do context 'filtering by project_id' do
context 'when include_ancestor_groups is true' do context 'when include_ancestor_groups is true' do
let!(:sub_project) { create(:project, namespace: private_subgroup_1 ) } let!(:sub_project) { create(:project, namespace: private_subgroup_1 ) }
......
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