debian-mirror-gitlab/spec/policies/merge_request_policy_spec.rb

181 lines
5.1 KiB
Ruby
Raw Permalink Normal View History

2019-12-26 22:10:19 +05:30
# frozen_string_literal: true
2019-07-07 11:18:12 +05:30
require 'spec_helper'
2020-07-28 23:09:34 +05:30
RSpec.describe MergeRequestPolicy do
2019-07-07 11:18:12 +05:30
include ExternalAuthorizationServiceHelpers
let(:guest) { create(:user) }
let(:author) { create(:user) }
let(:developer) { create(:user) }
2019-09-04 21:01:54 +05:30
let(:non_team_member) { create(:user) }
2019-07-07 11:18:12 +05:30
let(:project) { create(:project, :public) }
def permissions(user, merge_request)
described_class.new(user, merge_request)
end
before do
project.add_guest(guest)
project.add_guest(author)
project.add_developer(developer)
end
2020-05-24 23:13:21 +05:30
mr_perms = %i[create_merge_request_in
2019-09-04 21:01:54 +05:30
create_merge_request_from
read_merge_request
2021-01-29 00:20:46 +05:30
create_todo
2020-07-28 23:09:34 +05:30
approve_merge_request
2019-09-04 21:01:54 +05:30
create_note].freeze
shared_examples_for 'a denied user' do
let(:perms) { permissions(subject, merge_request) }
2020-05-24 23:13:21 +05:30
mr_perms.each do |thing|
2019-09-04 21:01:54 +05:30
it "cannot #{thing}" do
expect(perms).to be_disallowed(thing)
end
end
end
shared_examples_for 'a user with access' do
let(:perms) { permissions(subject, merge_request) }
2020-05-24 23:13:21 +05:30
mr_perms.each do |thing|
2019-09-04 21:01:54 +05:30
it "can #{thing}" do
expect(perms).to be_allowed(thing)
end
end
end
2021-01-29 00:20:46 +05:30
context 'when merge request is public' do
context 'and user is anonymous' do
let(:merge_request) { create(:merge_request, source_project: project, target_project: project, author: author) }
subject { permissions(nil, merge_request) }
it do
is_expected.to be_disallowed(:create_todo)
end
end
end
2019-09-04 21:01:54 +05:30
context 'when merge requests have been disabled' do
let!(:merge_request) { create(:merge_request, source_project: project, target_project: project, author: author) }
before do
2020-10-24 23:57:45 +05:30
project.project_feature.update!(merge_requests_access_level: ProjectFeature::DISABLED)
2019-09-04 21:01:54 +05:30
end
describe 'the author' do
subject { author }
2019-12-21 20:55:43 +05:30
2019-09-04 21:01:54 +05:30
it_behaves_like 'a denied user'
end
describe 'a guest' do
subject { guest }
2019-12-21 20:55:43 +05:30
2019-09-04 21:01:54 +05:30
it_behaves_like 'a denied user'
end
describe 'a developer' do
subject { developer }
2019-12-21 20:55:43 +05:30
2019-09-04 21:01:54 +05:30
it_behaves_like 'a denied user'
end
describe 'any other user' do
subject { non_team_member }
2019-12-21 20:55:43 +05:30
2019-09-04 21:01:54 +05:30
it_behaves_like 'a denied user'
end
end
context 'when merge requests are private' do
let!(:merge_request) { create(:merge_request, source_project: project, target_project: project, author: author) }
before do
2020-10-24 23:57:45 +05:30
project.update!(visibility_level: Gitlab::VisibilityLevel::PUBLIC)
project.project_feature.update!(merge_requests_access_level: ProjectFeature::PRIVATE)
2019-09-04 21:01:54 +05:30
end
describe 'a non-team-member' do
subject { non_team_member }
2019-12-21 20:55:43 +05:30
2019-09-04 21:01:54 +05:30
it_behaves_like 'a denied user'
end
describe 'a developer' do
subject { developer }
2019-12-21 20:55:43 +05:30
2019-09-04 21:01:54 +05:30
it_behaves_like 'a user with access'
end
end
2019-07-07 11:18:12 +05:30
context 'when merge request is unlocked' do
let(:merge_request) { create(:merge_request, :closed, source_project: project, target_project: project, author: author) }
it 'allows author to reopen merge request' do
expect(permissions(author, merge_request)).to be_allowed(:reopen_merge_request)
end
it 'allows developer to reopen merge request' do
expect(permissions(developer, merge_request)).to be_allowed(:reopen_merge_request)
end
it 'prevents guest from reopening merge request' do
expect(permissions(guest, merge_request)).to be_disallowed(:reopen_merge_request)
end
end
context 'when merge request is locked' do
let(:merge_request_locked) { create(:merge_request, :closed, discussion_locked: true, source_project: project, target_project: project, author: author) }
it 'prevents author from reopening merge request' do
expect(permissions(author, merge_request_locked)).to be_disallowed(:reopen_merge_request)
end
it 'prevents developer from reopening merge request' do
expect(permissions(developer, merge_request_locked)).to be_disallowed(:reopen_merge_request)
end
it 'prevents guests from reopening merge request' do
expect(permissions(guest, merge_request_locked)).to be_disallowed(:reopen_merge_request)
end
2019-09-04 21:01:54 +05:30
context 'when the user is not a project member' do
let(:user) { create(:user) }
it 'cannot create a note' do
expect(permissions(user, merge_request_locked)).to be_disallowed(:create_note)
end
end
context 'when the user is project member, with at least guest access' do
let(:user) { guest }
it 'can create a note' do
expect(permissions(user, merge_request_locked)).to be_allowed(:create_note)
end
end
2019-07-07 11:18:12 +05:30
end
context 'with external authorization enabled' do
let(:user) { create(:user) }
let(:project) { create(:project, :public) }
let(:merge_request) { create(:merge_request, source_project: project) }
let(:policies) { described_class.new(user, merge_request) }
before do
enable_external_authorization_service_check
end
it 'can read the issue iid without accessing the external service' do
expect(::Gitlab::ExternalAuthorization).not_to receive(:access_allowed?)
expect(policies).to be_allowed(:read_merge_request_iid)
end
end
end