Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGitLab Bot <gitlab-bot@gitlab.com>2022-07-20 18:40:28 +0300
committerGitLab Bot <gitlab-bot@gitlab.com>2022-07-20 18:40:28 +0300
commitb595cb0c1dec83de5bdee18284abe86614bed33b (patch)
tree8c3d4540f193c5ff98019352f554e921b3a41a72 /spec/policies/merge_request_policy_spec.rb
parent2f9104a328fc8a4bddeaa4627b595166d24671d0 (diff)
Add latest changes from gitlab-org/gitlab@15-2-stable-eev15.2.0-rc42
Diffstat (limited to 'spec/policies/merge_request_policy_spec.rb')
-rw-r--r--spec/policies/merge_request_policy_spec.rb62
1 files changed, 53 insertions, 9 deletions
diff --git a/spec/policies/merge_request_policy_spec.rb b/spec/policies/merge_request_policy_spec.rb
index e05de25f182..dd42e1b9313 100644
--- a/spec/policies/merge_request_policy_spec.rb
+++ b/spec/policies/merge_request_policy_spec.rb
@@ -51,7 +51,8 @@ RSpec.describe MergeRequestPolicy do
end
context 'when merge request is public' do
- let(:merge_request) { create(:merge_request, source_project: project, target_project: project, author: author) }
+ let(:merge_request) { create(:merge_request, source_project: project, target_project: project, author: user) }
+ let(:user) { author }
context 'and user is anonymous' do
subject { permissions(nil, merge_request) }
@@ -61,19 +62,62 @@ RSpec.describe MergeRequestPolicy do
end
end
- describe 'the author, who became a guest' do
- subject { permissions(author, merge_request) }
+ context 'and user is author' do
+ subject { permissions(user, merge_request) }
- it do
- is_expected.to be_allowed(:update_merge_request)
+ context 'and the user is a guest' do
+ let(:user) { guest }
+
+ it do
+ is_expected.to be_allowed(:update_merge_request)
+ end
+
+ it do
+ is_expected.to be_allowed(:reopen_merge_request)
+ end
+
+ it do
+ is_expected.to be_allowed(:approve_merge_request)
+ end
end
- it do
- is_expected.to be_allowed(:reopen_merge_request)
+ context 'and the user is a group member' do
+ let(:project) { create(:project, :public, group: group) }
+ let(:group) { create(:group) }
+ let(:user) { non_team_member }
+
+ before do
+ group.add_guest(non_team_member)
+ end
+
+ it do
+ is_expected.to be_allowed(:approve_merge_request)
+ end
end
- it do
- is_expected.to be_allowed(:approve_merge_request)
+ context 'and the user is a member of a shared group' do
+ let(:user) { non_team_member }
+
+ before do
+ group = create(:group)
+ project.project_group_links.create!(
+ group: group,
+ group_access: Gitlab::Access::DEVELOPER)
+
+ group.add_guest(non_team_member)
+ end
+
+ it do
+ is_expected.to be_allowed(:approve_merge_request)
+ end
+ end
+
+ context 'and the user is not a project member' do
+ let(:user) { non_team_member }
+
+ it do
+ is_expected.not_to be_allowed(:approve_merge_request)
+ end
end
end
end