2019-04-15 06:17:05 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2016-12-08 20:56:31 -05:00
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
describe SearchController do
|
2019-04-09 11:38:58 -04:00
|
|
|
include ExternalAuthorizationServiceHelpers
|
|
|
|
|
2019-01-16 07:09:29 -05:00
|
|
|
let(:user) { create(:user) }
|
2016-12-08 20:56:31 -05:00
|
|
|
|
|
|
|
before do
|
|
|
|
sign_in(user)
|
|
|
|
end
|
|
|
|
|
2019-04-24 13:12:20 -04:00
|
|
|
context 'uses the right partials depending on scope' do
|
|
|
|
using RSpec::Parameterized::TableSyntax
|
|
|
|
render_views
|
|
|
|
|
|
|
|
set(:project) { create(:project, :public, :repository, :wiki_repo) }
|
|
|
|
|
|
|
|
subject { get(:show, params: { project_id: project.id, scope: scope, search: 'merge' }) }
|
|
|
|
|
|
|
|
where(:partial, :scope) do
|
|
|
|
'_blob' | :blobs
|
|
|
|
'_wiki_blob' | :wiki_blobs
|
|
|
|
'_commit' | :commits
|
|
|
|
end
|
|
|
|
|
|
|
|
with_them do
|
|
|
|
it do
|
|
|
|
project_wiki = create(:project_wiki, project: project, user: user)
|
|
|
|
create(:wiki_page, wiki: project_wiki, attrs: { title: 'merge', content: 'merge' })
|
|
|
|
|
|
|
|
expect(subject).to render_template("search/results/#{partial}")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-12-08 20:56:31 -05:00
|
|
|
it 'finds issue comments' do
|
2017-08-02 15:55:11 -04:00
|
|
|
project = create(:project, :public)
|
2016-12-08 20:56:31 -05:00
|
|
|
note = create(:note_on_issue, project: project)
|
|
|
|
|
2018-12-17 17:52:17 -05:00
|
|
|
get :show, params: { project_id: project.id, scope: 'notes', search: note.note }
|
2016-12-08 20:56:31 -05:00
|
|
|
|
|
|
|
expect(assigns[:search_objects].first).to eq note
|
|
|
|
end
|
|
|
|
|
2017-12-11 09:21:06 -05:00
|
|
|
context 'when the user cannot read cross project' do
|
|
|
|
before do
|
|
|
|
allow(Ability).to receive(:allowed?).and_call_original
|
|
|
|
allow(Ability).to receive(:allowed?)
|
|
|
|
.with(user, :read_cross_project, :global) { false }
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'still allows accessing the search page' do
|
|
|
|
get :show
|
|
|
|
|
|
|
|
expect(response).to have_gitlab_http_status(200)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'still blocks searches without a project_id' do
|
2018-12-17 17:52:17 -05:00
|
|
|
get :show, params: { search: 'hello' }
|
2017-12-11 09:21:06 -05:00
|
|
|
|
2018-06-04 11:04:04 -04:00
|
|
|
expect(response).to have_gitlab_http_status(403)
|
2017-12-11 09:21:06 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
it 'allows searches with a project_id' do
|
2018-12-17 17:52:17 -05:00
|
|
|
get :show, params: { search: 'hello', project_id: create(:project, :public).id }
|
2017-12-11 09:21:06 -05:00
|
|
|
|
|
|
|
expect(response).to have_gitlab_http_status(200)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-12-08 20:56:31 -05:00
|
|
|
context 'on restricted projects' do
|
|
|
|
context 'when signed out' do
|
2017-06-14 14:18:56 -04:00
|
|
|
before do
|
|
|
|
sign_out(user)
|
|
|
|
end
|
2016-12-08 20:56:31 -05:00
|
|
|
|
|
|
|
it "doesn't expose comments on issues" do
|
2017-08-02 15:55:11 -04:00
|
|
|
project = create(:project, :public, :issues_private)
|
2016-12-08 20:56:31 -05:00
|
|
|
note = create(:note_on_issue, project: project)
|
|
|
|
|
2018-12-17 17:52:17 -05:00
|
|
|
get :show, params: { project_id: project.id, scope: 'notes', search: note.note }
|
2016-12-08 20:56:31 -05:00
|
|
|
|
|
|
|
expect(assigns[:search_objects].count).to eq(0)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it "doesn't expose comments on merge_requests" do
|
2017-08-02 15:55:11 -04:00
|
|
|
project = create(:project, :public, :merge_requests_private)
|
2016-12-08 20:56:31 -05:00
|
|
|
note = create(:note_on_merge_request, project: project)
|
|
|
|
|
2018-12-17 17:52:17 -05:00
|
|
|
get :show, params: { project_id: project.id, scope: 'notes', search: note.note }
|
2016-12-08 20:56:31 -05:00
|
|
|
|
|
|
|
expect(assigns[:search_objects].count).to eq(0)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "doesn't expose comments on snippets" do
|
2017-08-02 15:55:11 -04:00
|
|
|
project = create(:project, :public, :snippets_private)
|
2016-12-08 20:56:31 -05:00
|
|
|
note = create(:note_on_project_snippet, project: project)
|
|
|
|
|
2018-12-17 17:52:17 -05:00
|
|
|
get :show, params: { project_id: project.id, scope: 'notes', search: note.note }
|
2016-12-08 20:56:31 -05:00
|
|
|
|
|
|
|
expect(assigns[:search_objects].count).to eq(0)
|
|
|
|
end
|
|
|
|
end
|
2019-04-09 11:38:58 -04:00
|
|
|
|
|
|
|
context 'with external authorization service enabled' do
|
|
|
|
let(:project) { create(:project, namespace: user.namespace) }
|
|
|
|
let(:note) { create(:note_on_issue, project: project) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
enable_external_authorization_service_check
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'GET #show' do
|
|
|
|
it 'renders a 403 when no project is given' do
|
|
|
|
get :show, params: { scope: 'notes', search: note.note }
|
|
|
|
|
|
|
|
expect(response).to have_gitlab_http_status(403)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'renders a 200 when a project was set' do
|
|
|
|
get :show, params: { project_id: project.id, scope: 'notes', search: note.note }
|
|
|
|
|
|
|
|
expect(response).to have_gitlab_http_status(200)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'GET #autocomplete' do
|
|
|
|
it 'renders a 403 when no project is given' do
|
|
|
|
get :autocomplete, params: { term: 'hello' }
|
|
|
|
|
|
|
|
expect(response).to have_gitlab_http_status(403)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'renders a 200 when a project was set' do
|
|
|
|
get :autocomplete, params: { project_id: project.id, term: 'hello' }
|
|
|
|
|
|
|
|
expect(response).to have_gitlab_http_status(200)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2016-12-08 20:56:31 -05:00
|
|
|
end
|