summaryrefslogtreecommitdiff
path: root/spec
diff options
context:
space:
mode:
authorMichael Kozono <mkozono@gmail.com>2017-09-01 18:00:46 -0700
committerMichael Kozono <mkozono@gmail.com>2017-09-06 12:07:20 -0700
commit6c57734677746aa0e6695aa75990a85a7f95b50d (patch)
tree792a4a0a0a8856ca4702c4464862b53d4bd9461b /spec
parent1cc7f4a45d9e9fdf1943eb92d3cd2071ba497337 (diff)
downloadgitlab-ce-6c57734677746aa0e6695aa75990a85a7f95b50d.tar.gz
Enforce share_with_group_lock rules
…in Groups::UpdateService instead of only in the browser.
Diffstat (limited to 'spec')
-rw-r--r--spec/policies/group_policy_spec.rb48
-rw-r--r--spec/services/groups/update_service_spec.rb34
2 files changed, 82 insertions, 0 deletions
diff --git a/spec/policies/group_policy_spec.rb b/spec/policies/group_policy_spec.rb
index 7f832bfa563..9fa63982790 100644
--- a/spec/policies/group_policy_spec.rb
+++ b/spec/policies/group_policy_spec.rb
@@ -242,4 +242,52 @@ describe GroupPolicy do
end
end
end
+
+ describe 'change_share_with_group_lock' do
+ context 'when the group has a parent' do
+ let(:group) { create(:group, parent: parent) }
+
+ context 'when the parent share_with_group_lock is enabled' do
+ let(:parent) { create(:group, share_with_group_lock: true) }
+ let(:current_user) { owner }
+
+ context 'when current_user owns the parent' do
+ before do
+ parent.add_owner(owner)
+ end
+
+ it { expect_allowed(:change_share_with_group_lock) }
+ end
+
+ context 'when current_user owns the group but not the parent' do
+ it { expect_disallowed(:change_share_with_group_lock) }
+ end
+ end
+
+ context 'when the parent share_with_group_lock is disabled' do
+ let(:parent) { create(:group) }
+ let(:current_user) { owner }
+
+ context 'when current_user owns the parent' do
+ before do
+ parent.add_owner(owner)
+ end
+
+ it { expect_allowed(:change_share_with_group_lock) }
+ end
+
+ context 'when current_user owns the group but not the parent' do
+ it { expect_allowed(:change_share_with_group_lock) }
+ end
+ end
+ end
+
+ context 'when the group does not have a parent' do
+ context 'when current_user owns the group' do
+ let(:current_user) { owner }
+
+ it { expect_allowed(:change_share_with_group_lock) }
+ end
+ end
+ end
end
diff --git a/spec/services/groups/update_service_spec.rb b/spec/services/groups/update_service_spec.rb
index 44f22a3b37b..aa8e058903b 100644
--- a/spec/services/groups/update_service_spec.rb
+++ b/spec/services/groups/update_service_spec.rb
@@ -100,4 +100,38 @@ describe Groups::UpdateService do
end
end
end
+
+ context 'for a subgroup' do
+ let(:subgroup) { create(:group, :private, parent: private_group) }
+
+ context 'when the parent group share_with_group_lock is enabled' do
+ before do
+ private_group.update_column(:share_with_group_lock, true)
+ end
+
+ context 'for the parent group owner' do
+ it 'allows disabling share_with_group_lock' do
+ private_group.add_owner(user)
+
+ result = described_class.new(subgroup, user, share_with_group_lock: false).execute
+
+ expect(result).to be_truthy
+ expect(subgroup.reload.share_with_group_lock).to be_falsey
+ end
+ end
+
+ context 'for a subgroup owner (who does not own the parent)' do
+ it 'does not allow disabling share_with_group_lock' do
+ subgroup_owner = create(:user)
+ subgroup.add_owner(subgroup_owner)
+
+ result = described_class.new(subgroup, subgroup_owner, share_with_group_lock: false).execute
+
+ expect(result).to be_falsey
+ expect(subgroup.errors.full_messages.first).to match(/cannot be disabled when the parent group Share lock is enabled, except by the owner of the parent group/)
+ expect(subgroup.reload.share_with_group_lock).to be_truthy
+ end
+ end
+ end
+ end
end