debian-mirror-gitlab/spec/lib/gitlab/project_search_results_spec.rb

139 lines
4.8 KiB
Ruby
Raw Normal View History

2015-09-11 14:41:01 +05:30
require 'spec_helper'
2015-12-23 02:04:40 +05:30
describe Gitlab::ProjectSearchResults, lib: true do
2016-06-02 11:05:42 +05:30
let(:user) { create(:user) }
2015-09-11 14:41:01 +05:30
let(:project) { create(:project) }
let(:query) { 'hello world' }
describe 'initialize with empty ref' do
2016-06-02 11:05:42 +05:30
let(:results) { Gitlab::ProjectSearchResults.new(user, project, query, '') }
2015-09-11 14:41:01 +05:30
it { expect(results.project).to eq(project) }
it { expect(results.repository_ref).to be_nil }
2015-11-26 14:37:03 +05:30
it { expect(results.query).to eq('hello world') }
2015-09-11 14:41:01 +05:30
end
describe 'initialize with ref' do
let(:ref) { 'refs/heads/test' }
2016-06-02 11:05:42 +05:30
let(:results) { Gitlab::ProjectSearchResults.new(user, project, query, ref) }
2015-09-11 14:41:01 +05:30
it { expect(results.project).to eq(project) }
it { expect(results.repository_ref).to eq(ref) }
2015-11-26 14:37:03 +05:30
it { expect(results.query).to eq('hello world') }
2015-09-11 14:41:01 +05:30
end
2016-06-02 11:05:42 +05:30
2017-01-15 13:20:01 +05:30
it 'does not list issues on private projects' do
issue = create(:issue, project: project)
results = described_class.new(user, project, issue.title)
expect(results.objects('issues')).not_to include issue
end
2016-06-02 11:05:42 +05:30
describe 'confidential issues' do
let(:query) { 'issue' }
let(:author) { create(:user) }
let(:assignee) { create(:user) }
let(:non_member) { create(:user) }
let(:member) { create(:user) }
let(:admin) { create(:admin) }
2017-01-15 13:20:01 +05:30
let(:project) { create(:empty_project, :internal) }
2016-06-02 11:05:42 +05:30
let!(:issue) { create(:issue, project: project, title: 'Issue 1') }
let!(:security_issue_1) { create(:issue, :confidential, project: project, title: 'Security issue 1', author: author) }
let!(:security_issue_2) { create(:issue, :confidential, title: 'Security issue 2', project: project, assignee: assignee) }
2016-09-13 17:45:13 +05:30
it 'does not list project confidential issues for non project members' do
2016-06-02 11:05:42 +05:30
results = described_class.new(non_member, project, query)
issues = results.objects('issues')
expect(issues).to include issue
expect(issues).not_to include security_issue_1
expect(issues).not_to include security_issue_2
expect(results.issues_count).to eq 1
end
2016-09-13 17:45:13 +05:30
it 'does not list project confidential issues for project members with guest role' do
project.team << [member, :guest]
results = described_class.new(member, project, query)
issues = results.objects('issues')
expect(issues).to include issue
expect(issues).not_to include security_issue_1
expect(issues).not_to include security_issue_2
expect(results.issues_count).to eq 1
end
2016-09-13 17:45:13 +05:30
it 'lists project confidential issues for author' do
2016-06-02 11:05:42 +05:30
results = described_class.new(author, project, query)
issues = results.objects('issues')
expect(issues).to include issue
expect(issues).to include security_issue_1
expect(issues).not_to include security_issue_2
expect(results.issues_count).to eq 2
end
2016-09-13 17:45:13 +05:30
it 'lists project confidential issues for assignee' do
2016-06-02 11:05:42 +05:30
results = described_class.new(assignee, project.id, query)
issues = results.objects('issues')
expect(issues).to include issue
expect(issues).not_to include security_issue_1
expect(issues).to include security_issue_2
expect(results.issues_count).to eq 2
end
2016-09-13 17:45:13 +05:30
it 'lists project confidential issues for project members' do
2016-06-02 11:05:42 +05:30
project.team << [member, :developer]
results = described_class.new(member, project, query)
issues = results.objects('issues')
expect(issues).to include issue
expect(issues).to include security_issue_1
expect(issues).to include security_issue_2
expect(results.issues_count).to eq 3
end
2016-09-13 17:45:13 +05:30
it 'lists all project issues for admin' do
2016-06-02 11:05:42 +05:30
results = described_class.new(admin, project, query)
issues = results.objects('issues')
expect(issues).to include issue
expect(issues).to include security_issue_1
expect(issues).to include security_issue_2
expect(results.issues_count).to eq 3
end
end
2017-01-15 13:20:01 +05:30
describe 'notes search' do
it 'lists notes' do
project = create(:empty_project, :public)
note = create(:note, project: project)
results = described_class.new(user, project, note.note)
expect(results.objects('notes')).to include note
end
it "doesn't list issue notes when access is restricted" do
project = create(:empty_project, :public, issues_access_level: ProjectFeature::PRIVATE)
note = create(:note_on_issue, project: project)
results = described_class.new(user, project, note.note)
expect(results.objects('notes')).not_to include note
end
it "doesn't list merge_request notes when access is restricted" do
project = create(:empty_project, :public, merge_requests_access_level: ProjectFeature::PRIVATE)
note = create(:note_on_merge_request, project: project)
results = described_class.new(user, project, note.note)
expect(results.objects('notes')).not_to include note
end
end
2015-09-11 14:41:01 +05:30
end