Refactor group search out of global search
This commit is contained in:
parent
aecaaa67c3
commit
ab529cddac
5 changed files with 64 additions and 28 deletions
|
@ -7,16 +7,13 @@ module Search
|
||||||
end
|
end
|
||||||
|
|
||||||
def execute
|
def execute
|
||||||
group = Group.find_by(id: params[:group_id]) if params[:group_id].present?
|
|
||||||
projects = ProjectsFinder.new(current_user: current_user).execute
|
|
||||||
|
|
||||||
if group
|
|
||||||
projects = projects.inside_path(group.full_path)
|
|
||||||
end
|
|
||||||
|
|
||||||
Gitlab::SearchResults.new(current_user, projects, params[:search])
|
Gitlab::SearchResults.new(current_user, projects, params[:search])
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def projects
|
||||||
|
@projects ||= ProjectsFinder.new(current_user: current_user).execute
|
||||||
|
end
|
||||||
|
|
||||||
def scope
|
def scope
|
||||||
@scope ||= begin
|
@scope ||= begin
|
||||||
allowed_scopes = %w[issues merge_requests milestones]
|
allowed_scopes = %w[issues merge_requests milestones]
|
||||||
|
|
18
app/services/search/group_service.rb
Normal file
18
app/services/search/group_service.rb
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
module Search
|
||||||
|
class GroupService < Search::GlobalService
|
||||||
|
attr_accessor :group
|
||||||
|
|
||||||
|
def initialize(user, group, params)
|
||||||
|
super(user, params)
|
||||||
|
|
||||||
|
@group = group
|
||||||
|
end
|
||||||
|
|
||||||
|
def projects
|
||||||
|
return Project.none unless group
|
||||||
|
return @projects if defined? @projects
|
||||||
|
|
||||||
|
@projects = super.inside_path(group.full_path)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -54,6 +54,8 @@ class SearchService
|
||||||
Search::ProjectService.new(project, current_user, params)
|
Search::ProjectService.new(project, current_user, params)
|
||||||
elsif show_snippets?
|
elsif show_snippets?
|
||||||
Search::SnippetService.new(current_user, params)
|
Search::SnippetService.new(current_user, params)
|
||||||
|
elsif group
|
||||||
|
Search::GroupService.new(current_user, group, params)
|
||||||
else
|
else
|
||||||
Search::GlobalService.new(current_user, params)
|
Search::GlobalService.new(current_user, params)
|
||||||
end
|
end
|
||||||
|
|
|
@ -40,27 +40,6 @@ describe Search::GlobalService, services: true do
|
||||||
|
|
||||||
expect(results.objects('projects')).to match_array [found_project]
|
expect(results.objects('projects')).to match_array [found_project]
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'nested group' do
|
|
||||||
let!(:nested_group) { create(:group, :nested) }
|
|
||||||
let!(:project) { create(:empty_project, namespace: nested_group) }
|
|
||||||
|
|
||||||
before do
|
|
||||||
project.add_master(user)
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'returns result from nested group' do
|
|
||||||
results = Search::GlobalService.new(user, search: project.path).execute
|
|
||||||
|
|
||||||
expect(results.objects('projects')).to match_array [project]
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'returns result from descendants when search inside group' do
|
|
||||||
results = Search::GlobalService.new(user, search: project.path, group_id: nested_group.parent).execute
|
|
||||||
|
|
||||||
expect(results.objects('projects')).to match_array [project]
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
40
spec/services/search/group_service_spec.rb
Normal file
40
spec/services/search/group_service_spec.rb
Normal file
|
@ -0,0 +1,40 @@
|
||||||
|
require 'spec_helper'
|
||||||
|
|
||||||
|
describe Search::GroupService, services: true do
|
||||||
|
shared_examples_for 'group search' do
|
||||||
|
context 'finding projects by name' do
|
||||||
|
let(:user) { create(:user) }
|
||||||
|
let(:term) { "Project Name" }
|
||||||
|
let(:nested_group) { create(:group, :nested) }
|
||||||
|
|
||||||
|
# These projects shouldn't be found
|
||||||
|
let!(:outside_project) { create(:empty_project, :public, name: "Outside #{term}") }
|
||||||
|
let!(:private_project) { create(:empty_project, :private, namespace: nested_group, name: "Private #{term}" )}
|
||||||
|
let!(:other_project) { create(:empty_project, :public, namespace: nested_group, name: term.reverse) }
|
||||||
|
|
||||||
|
# These projects should be found
|
||||||
|
let!(:project1) { create(:empty_project, :internal, namespace: nested_group, name: "Inner #{term} 1") }
|
||||||
|
let!(:project2) { create(:empty_project, :internal, namespace: nested_group, name: "Inner #{term} 2") }
|
||||||
|
let!(:project3) { create(:empty_project, :internal, namespace: nested_group.parent, name: "Outer #{term}") }
|
||||||
|
|
||||||
|
let(:results) { Search::GroupService.new(user, search_group, search: term).execute }
|
||||||
|
subject { results.objects('projects') }
|
||||||
|
|
||||||
|
context 'in parent group' do
|
||||||
|
let(:search_group) { nested_group.parent }
|
||||||
|
|
||||||
|
it { is_expected.to match_array([project1, project2, project3]) }
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'in subgroup' do
|
||||||
|
let(:search_group) { nested_group }
|
||||||
|
|
||||||
|
it { is_expected.to match_array([project1, project2]) }
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'basic search' do
|
||||||
|
include_examples 'group search'
|
||||||
|
end
|
||||||
|
end
|
Loading…
Reference in a new issue