debian-mirror-gitlab/spec/controllers/search_controller_spec.rb

228 lines
7.1 KiB
Ruby
Raw Normal View History

2019-07-31 22:56:46 +05:30
# frozen_string_literal: true
2017-01-15 13:20:01 +05:30
require 'spec_helper'
describe SearchController do
2019-07-07 11:18:12 +05:30
include ExternalAuthorizationServiceHelpers
2019-03-02 22:35:43 +05:30
let(:user) { create(:user) }
2017-01-15 13:20:01 +05:30
before do
sign_in(user)
end
2019-10-12 21:52:04 +05:30
shared_examples_for 'when the user cannot read cross project' do |action, params|
2019-09-30 21:07:59 +05:30
before do
2019-10-12 21:52:04 +05:30
allow(Ability).to receive(:allowed?).and_call_original
allow(Ability).to receive(:allowed?)
.with(user, :read_cross_project, :global) { false }
2019-09-30 21:07:59 +05:30
end
2019-10-12 21:52:04 +05:30
it 'blocks access without a project_id' do
get action, params: params
2019-07-07 11:18:12 +05:30
2020-03-13 15:44:24 +05:30
expect(response).to have_gitlab_http_status(:forbidden)
2019-07-07 11:18:12 +05:30
end
2019-10-12 21:52:04 +05:30
it 'allows access with a project_id' do
get action, params: params.merge(project_id: create(:project, :public).id)
2019-07-07 11:18:12 +05:30
2020-03-13 15:44:24 +05:30
expect(response).to have_gitlab_http_status(:ok)
2019-07-07 11:18:12 +05:30
end
end
2019-10-12 21:52:04 +05:30
shared_examples_for 'with external authorization service enabled' do |action, params|
let(:project) { create(:project, namespace: user.namespace) }
let(:note) { create(:note_on_issue, project: project) }
2019-09-30 21:07:59 +05:30
2019-10-12 21:52:04 +05:30
before do
enable_external_authorization_service_check
2019-09-30 21:07:59 +05:30
end
2017-01-15 13:20:01 +05:30
2019-10-12 21:52:04 +05:30
it 'renders a 403 when no project is given' do
get action, params: params
2017-01-15 13:20:01 +05:30
2020-03-13 15:44:24 +05:30
expect(response).to have_gitlab_http_status(:forbidden)
2018-03-27 19:54:05 +05:30
end
2019-10-12 21:52:04 +05:30
it 'renders a 200 when a project was set' do
get action, params: params.merge(project_id: project.id)
2018-03-27 19:54:05 +05:30
2020-03-13 15:44:24 +05:30
expect(response).to have_gitlab_http_status(:ok)
2018-03-27 19:54:05 +05:30
end
2019-10-12 21:52:04 +05:30
end
2018-03-27 19:54:05 +05:30
2019-10-12 21:52:04 +05:30
describe 'GET #show' do
it_behaves_like 'when the user cannot read cross project', :show, { search: 'hello' } do
it 'still allows accessing the search page' do
get :show
2018-03-27 19:54:05 +05:30
2020-03-13 15:44:24 +05:30
expect(response).to have_gitlab_http_status(:ok)
2019-10-12 21:52:04 +05:30
end
2018-03-27 19:54:05 +05:30
end
2019-10-12 21:52:04 +05:30
it_behaves_like 'with external authorization service enabled', :show, { search: 'hello' }
2018-03-27 19:54:05 +05:30
2019-10-12 21:52:04 +05:30
context 'uses the right partials depending on scope' do
using RSpec::Parameterized::TableSyntax
render_views
2019-12-21 20:55:43 +05:30
let_it_be(:project) { create(:project, :public, :repository, :wiki_repo) }
2018-03-27 19:54:05 +05:30
2017-09-10 17:25:29 +05:30
before do
2019-10-12 21:52:04 +05:30
expect(::Gitlab::GitalyClient).to receive(:allow_ref_name_caching).and_call_original
2017-09-10 17:25:29 +05:30
end
2017-01-15 13:20:01 +05:30
2019-10-12 21:52:04 +05:30
subject { get(:show, params: { project_id: project.id, scope: scope, search: 'merge' }) }
2017-01-15 13:20:01 +05:30
2019-10-12 21:52:04 +05:30
where(:partial, :scope) do
'_blob' | :blobs
'_wiki_blob' | :wiki_blobs
'_commit' | :commits
end
2017-01-15 13:20:01 +05:30
2019-10-12 21:52:04 +05:30
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
2017-01-15 13:20:01 +05:30
end
end
2019-10-12 21:52:04 +05:30
context 'global search' do
2020-03-13 15:44:24 +05:30
using RSpec::Parameterized::TableSyntax
2019-10-12 21:52:04 +05:30
render_views
2017-01-15 13:20:01 +05:30
2019-10-12 21:52:04 +05:30
it 'omits pipeline status from load' do
project = create(:project, :public)
expect(Gitlab::Cache::Ci::ProjectPipelineStatus).not_to receive(:load_in_batch_for_projects)
get :show, params: { scope: 'projects', search: project.name }
2017-01-15 13:20:01 +05:30
2019-10-12 21:52:04 +05:30
expect(assigns[:search_objects].first).to eq project
end
2020-03-13 15:44:24 +05:30
context 'check search term length' do
let(:search_queries) do
char_limit = SearchService::SEARCH_CHAR_LIMIT
term_limit = SearchService::SEARCH_TERM_LIMIT
{
chars_under_limit: ('a' * (char_limit - 1)),
chars_over_limit: ('a' * (char_limit + 1)),
terms_under_limit: ('abc ' * (term_limit - 1)),
terms_over_limit: ('abc ' * (term_limit + 1))
}
end
where(:string_name, :expectation) do
:chars_under_limit | :not_to_set_flash
:chars_over_limit | :set_chars_flash
:terms_under_limit | :not_to_set_flash
:terms_over_limit | :set_terms_flash
end
with_them do
it do
get :show, params: { scope: 'projects', search: search_queries[string_name] }
case expectation
when :not_to_set_flash
expect(controller).not_to set_flash[:alert]
when :set_chars_flash
expect(controller).to set_flash[:alert].to(/characters/)
when :set_terms_flash
expect(controller).to set_flash[:alert].to(/terms/)
end
end
end
end
2017-01-15 13:20:01 +05:30
end
2020-04-08 14:13:33 +05:30
context 'snippet search' do
it 'forces title search' do
get :show, params: { scope: 'snippet_blobs', snippets: 'true', search: 'foo' }
expect(assigns[:scope]).to eq('snippet_titles')
end
end
2019-10-12 21:52:04 +05:30
it 'finds issue comments' do
project = create(:project, :public)
note = create(:note_on_issue, project: project)
2017-01-15 13:20:01 +05:30
2019-02-15 15:39:39 +05:30
get :show, params: { project_id: project.id, scope: 'notes', search: note.note }
2017-01-15 13:20:01 +05:30
2019-10-12 21:52:04 +05:30
expect(assigns[:search_objects].first).to eq note
2017-01-15 13:20:01 +05:30
end
2019-07-07 11:18:12 +05:30
2019-10-12 21:52:04 +05:30
context 'on restricted projects' do
context 'when signed out' do
before do
sign_out(user)
end
2019-07-07 11:18:12 +05:30
2019-10-12 21:52:04 +05:30
it "doesn't expose comments on issues" do
project = create(:project, :public, :issues_private)
note = create(:note_on_issue, project: project)
2019-07-07 11:18:12 +05:30
2019-10-12 21:52:04 +05:30
get :show, params: { project_id: project.id, scope: 'notes', search: note.note }
2019-07-07 11:18:12 +05:30
2019-10-12 21:52:04 +05:30
expect(assigns[:search_objects].count).to eq(0)
end
2019-07-07 11:18:12 +05:30
end
2019-10-12 21:52:04 +05:30
it "doesn't expose comments on merge_requests" do
project = create(:project, :public, :merge_requests_private)
note = create(:note_on_merge_request, project: project)
2019-07-07 11:18:12 +05:30
get :show, params: { project_id: project.id, scope: 'notes', search: note.note }
2019-10-12 21:52:04 +05:30
expect(assigns[:search_objects].count).to eq(0)
2019-07-07 11:18:12 +05:30
end
2019-10-12 21:52:04 +05:30
it "doesn't expose comments on snippets" do
project = create(:project, :public, :snippets_private)
note = create(:note_on_project_snippet, project: project)
2019-07-07 11:18:12 +05:30
2019-10-12 21:52:04 +05:30
get :show, params: { project_id: project.id, scope: 'notes', search: note.note }
expect(assigns[:search_objects].count).to eq(0)
2019-07-07 11:18:12 +05:30
end
2019-10-12 21:52:04 +05:30
end
end
2019-07-07 11:18:12 +05:30
2019-10-12 21:52:04 +05:30
describe 'GET #count' do
it_behaves_like 'when the user cannot read cross project', :count, { search: 'hello', scope: 'projects' }
it_behaves_like 'with external authorization service enabled', :count, { search: 'hello', scope: 'projects' }
2019-07-07 11:18:12 +05:30
2019-10-12 21:52:04 +05:30
it 'returns the result count for the given term and scope' do
create(:project, :public, name: 'hello world')
create(:project, :public, name: 'foo bar')
get :count, params: { search: 'hello', scope: 'projects' }
2020-03-13 15:44:24 +05:30
expect(response).to have_gitlab_http_status(:ok)
2019-10-12 21:52:04 +05:30
expect(json_response).to eq({ 'count' => '1' })
end
it 'raises an error if search term is missing' do
expect do
get :count, params: { scope: 'projects' }
end.to raise_error(ActionController::ParameterMissing)
2019-07-07 11:18:12 +05:30
end
2019-10-12 21:52:04 +05:30
it 'raises an error if search scope is missing' do
expect do
get :count, params: { search: 'hello' }
end.to raise_error(ActionController::ParameterMissing)
end
end
describe 'GET #autocomplete' do
it_behaves_like 'when the user cannot read cross project', :autocomplete, { term: 'hello' }
it_behaves_like 'with external authorization service enabled', :autocomplete, { term: 'hello' }
2019-07-07 11:18:12 +05:30
end
2017-01-15 13:20:01 +05:30
end