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

681 lines
19 KiB
Ruby
Raw Normal View History

2019-12-26 22:10:19 +05:30
# frozen_string_literal: true
2017-08-17 22:00:37 +05:30
require 'spec_helper'
2017-09-10 17:25:29 +05:30
describe GroupPolicy do
2019-07-07 11:18:12 +05:30
include_context 'GroupPolicy context'
2017-08-17 22:00:37 +05:30
2019-12-21 20:55:43 +05:30
context 'public group with no user' do
2018-05-09 12:01:36 +05:30
let(:group) { create(:group, :public) }
2017-08-17 22:00:37 +05:30
let(:current_user) { nil }
it do
2017-09-10 17:25:29 +05:30
expect_allowed(:read_group)
2019-12-21 20:55:43 +05:30
expect_allowed(*read_group_permissions)
2018-03-17 18:26:18 +05:30
expect_disallowed(:upload_file)
2017-09-10 17:25:29 +05:30
expect_disallowed(*reporter_permissions)
2018-03-17 18:26:18 +05:30
expect_disallowed(*developer_permissions)
2018-11-18 11:00:15 +05:30
expect_disallowed(*maintainer_permissions)
2017-09-10 17:25:29 +05:30
expect_disallowed(*owner_permissions)
2018-03-17 18:26:18 +05:30
expect_disallowed(:read_namespace)
2017-08-17 22:00:37 +05:30
end
end
2019-03-13 22:55:13 +05:30
context 'with no user and public project' do
let(:project) { create(:project, :public) }
let(:current_user) { nil }
before do
2019-07-07 11:18:12 +05:30
create(:project_group_link, project: project, group: group)
2019-03-13 22:55:13 +05:30
end
it { expect_disallowed(:read_group) }
2019-12-21 20:55:43 +05:30
it { expect_disallowed(*read_group_permissions) }
2019-03-13 22:55:13 +05:30
end
context 'with foreign user and public project' do
let(:project) { create(:project, :public) }
let(:current_user) { create(:user) }
before do
2019-07-07 11:18:12 +05:30
create(:project_group_link, project: project, group: group)
2019-03-13 22:55:13 +05:30
end
it { expect_disallowed(:read_group) }
2019-12-21 20:55:43 +05:30
it { expect_disallowed(*read_group_permissions) }
2019-03-13 22:55:13 +05:30
end
2018-05-09 12:01:36 +05:30
context 'has projects' do
let(:current_user) { create(:user) }
let(:project) { create(:project, namespace: group) }
before do
project.add_developer(current_user)
end
2019-12-21 20:55:43 +05:30
it { expect_allowed(*read_group_permissions) }
2018-05-09 12:01:36 +05:30
2019-10-12 21:52:04 +05:30
context 'in subgroups' do
2018-05-09 12:01:36 +05:30
let(:subgroup) { create(:group, :private, parent: group) }
let(:project) { create(:project, namespace: subgroup) }
2019-12-21 20:55:43 +05:30
it { expect_allowed(*read_group_permissions) }
2018-05-09 12:01:36 +05:30
end
end
2017-08-17 22:00:37 +05:30
context 'guests' do
let(:current_user) { guest }
it do
2019-12-21 20:55:43 +05:30
expect_allowed(*read_group_permissions)
2018-03-17 18:26:18 +05:30
expect_allowed(*guest_permissions)
2017-09-10 17:25:29 +05:30
expect_disallowed(*reporter_permissions)
2018-03-17 18:26:18 +05:30
expect_disallowed(*developer_permissions)
2018-11-18 11:00:15 +05:30
expect_disallowed(*maintainer_permissions)
2017-09-10 17:25:29 +05:30
expect_disallowed(*owner_permissions)
2017-08-17 22:00:37 +05:30
end
end
context 'reporter' do
let(:current_user) { reporter }
it do
2019-12-21 20:55:43 +05:30
expect_allowed(*read_group_permissions)
2018-03-17 18:26:18 +05:30
expect_allowed(*guest_permissions)
2017-09-10 17:25:29 +05:30
expect_allowed(*reporter_permissions)
2018-03-17 18:26:18 +05:30
expect_disallowed(*developer_permissions)
2018-11-18 11:00:15 +05:30
expect_disallowed(*maintainer_permissions)
2017-09-10 17:25:29 +05:30
expect_disallowed(*owner_permissions)
2017-08-17 22:00:37 +05:30
end
end
context 'developer' do
let(:current_user) { developer }
it do
2019-12-21 20:55:43 +05:30
expect_allowed(*read_group_permissions)
2018-03-17 18:26:18 +05:30
expect_allowed(*guest_permissions)
2017-09-10 17:25:29 +05:30
expect_allowed(*reporter_permissions)
2018-03-17 18:26:18 +05:30
expect_allowed(*developer_permissions)
2018-11-18 11:00:15 +05:30
expect_disallowed(*maintainer_permissions)
2017-09-10 17:25:29 +05:30
expect_disallowed(*owner_permissions)
2017-08-17 22:00:37 +05:30
end
end
2018-11-18 11:00:15 +05:30
context 'maintainer' do
let(:current_user) { maintainer }
2017-08-17 22:00:37 +05:30
2019-10-12 21:52:04 +05:30
context 'with subgroup_creation level set to maintainer' do
2019-12-21 20:55:43 +05:30
before_all do
group.update(subgroup_creation_level: ::Gitlab::Access::MAINTAINER_SUBGROUP_ACCESS)
2019-10-12 21:52:04 +05:30
end
it 'allows every maintainer permission plus creating subgroups' do
create_subgroup_permission = [:create_subgroup]
updated_maintainer_permissions =
maintainer_permissions + create_subgroup_permission
updated_owner_permissions =
owner_permissions - create_subgroup_permission
2019-12-21 20:55:43 +05:30
expect_allowed(*read_group_permissions)
2019-10-12 21:52:04 +05:30
expect_allowed(*guest_permissions)
expect_allowed(*reporter_permissions)
expect_allowed(*developer_permissions)
expect_allowed(*updated_maintainer_permissions)
expect_disallowed(*updated_owner_permissions)
end
end
context 'with subgroup_creation_level set to owner' do
it 'allows every maintainer permission' do
2019-12-21 20:55:43 +05:30
expect_allowed(*read_group_permissions)
2019-10-12 21:52:04 +05:30
expect_allowed(*guest_permissions)
expect_allowed(*reporter_permissions)
expect_allowed(*developer_permissions)
expect_allowed(*maintainer_permissions)
expect_disallowed(*owner_permissions)
end
2017-08-17 22:00:37 +05:30
end
end
context 'owner' do
let(:current_user) { owner }
it do
2019-12-21 20:55:43 +05:30
expect_allowed(*read_group_permissions)
2018-03-17 18:26:18 +05:30
expect_allowed(*guest_permissions)
2017-09-10 17:25:29 +05:30
expect_allowed(*reporter_permissions)
2018-03-17 18:26:18 +05:30
expect_allowed(*developer_permissions)
2018-11-18 11:00:15 +05:30
expect_allowed(*maintainer_permissions)
2017-09-10 17:25:29 +05:30
expect_allowed(*owner_permissions)
2017-08-17 22:00:37 +05:30
end
end
context 'admin' do
let(:current_user) { admin }
it do
2019-12-21 20:55:43 +05:30
expect_allowed(*read_group_permissions)
2018-03-17 18:26:18 +05:30
expect_allowed(*guest_permissions)
2017-09-10 17:25:29 +05:30
expect_allowed(*reporter_permissions)
2018-03-17 18:26:18 +05:30
expect_allowed(*developer_permissions)
2018-11-18 11:00:15 +05:30
expect_allowed(*maintainer_permissions)
2017-09-10 17:25:29 +05:30
expect_allowed(*owner_permissions)
2017-08-17 22:00:37 +05:30
end
end
2019-10-12 21:52:04 +05:30
describe 'private nested group use the highest access level from the group and inherited permissions' do
2019-12-21 20:55:43 +05:30
let_it_be(:nested_group) do
2019-10-12 21:52:04 +05:30
create(:group, :private, :owner_subgroup_creation_only, parent: group)
2018-03-17 18:26:18 +05:30
end
2017-08-17 22:00:37 +05:30
2019-12-21 20:55:43 +05:30
before_all do
2017-09-10 17:25:29 +05:30
nested_group.add_guest(guest)
nested_group.add_guest(reporter)
nested_group.add_guest(developer)
2018-11-18 11:00:15 +05:30
nested_group.add_guest(maintainer)
2017-09-10 17:25:29 +05:30
2018-11-20 20:47:30 +05:30
group.owners.destroy_all # rubocop: disable DestroyAll
2017-09-10 17:25:29 +05:30
group.add_guest(owner)
nested_group.add_owner(owner)
end
subject { described_class.new(current_user, nested_group) }
2017-08-17 22:00:37 +05:30
context 'with no user' do
let(:current_user) { nil }
it do
2019-12-21 20:55:43 +05:30
expect_disallowed(*read_group_permissions)
2018-03-17 18:26:18 +05:30
expect_disallowed(*guest_permissions)
2017-09-10 17:25:29 +05:30
expect_disallowed(*reporter_permissions)
2018-03-17 18:26:18 +05:30
expect_disallowed(*developer_permissions)
2018-11-18 11:00:15 +05:30
expect_disallowed(*maintainer_permissions)
2017-09-10 17:25:29 +05:30
expect_disallowed(*owner_permissions)
2017-08-17 22:00:37 +05:30
end
end
context 'guests' do
let(:current_user) { guest }
it do
2019-12-21 20:55:43 +05:30
expect_allowed(*read_group_permissions)
2018-03-17 18:26:18 +05:30
expect_allowed(*guest_permissions)
2017-09-10 17:25:29 +05:30
expect_disallowed(*reporter_permissions)
2018-03-17 18:26:18 +05:30
expect_disallowed(*developer_permissions)
2018-11-18 11:00:15 +05:30
expect_disallowed(*maintainer_permissions)
2017-09-10 17:25:29 +05:30
expect_disallowed(*owner_permissions)
2017-08-17 22:00:37 +05:30
end
end
context 'reporter' do
let(:current_user) { reporter }
it do
2019-12-21 20:55:43 +05:30
expect_allowed(*read_group_permissions)
2018-03-17 18:26:18 +05:30
expect_allowed(*guest_permissions)
2017-09-10 17:25:29 +05:30
expect_allowed(*reporter_permissions)
2018-03-17 18:26:18 +05:30
expect_disallowed(*developer_permissions)
2018-11-18 11:00:15 +05:30
expect_disallowed(*maintainer_permissions)
2017-09-10 17:25:29 +05:30
expect_disallowed(*owner_permissions)
2017-08-17 22:00:37 +05:30
end
end
context 'developer' do
let(:current_user) { developer }
it do
2019-12-21 20:55:43 +05:30
expect_allowed(*read_group_permissions)
2018-03-17 18:26:18 +05:30
expect_allowed(*guest_permissions)
2017-09-10 17:25:29 +05:30
expect_allowed(*reporter_permissions)
2018-03-17 18:26:18 +05:30
expect_allowed(*developer_permissions)
2018-11-18 11:00:15 +05:30
expect_disallowed(*maintainer_permissions)
2017-09-10 17:25:29 +05:30
expect_disallowed(*owner_permissions)
2017-08-17 22:00:37 +05:30
end
end
2018-11-18 11:00:15 +05:30
context 'maintainer' do
let(:current_user) { maintainer }
2017-08-17 22:00:37 +05:30
it do
2019-12-21 20:55:43 +05:30
expect_allowed(*read_group_permissions)
2018-03-17 18:26:18 +05:30
expect_allowed(*guest_permissions)
2017-09-10 17:25:29 +05:30
expect_allowed(*reporter_permissions)
2018-03-17 18:26:18 +05:30
expect_allowed(*developer_permissions)
2018-11-18 11:00:15 +05:30
expect_allowed(*maintainer_permissions)
2017-09-10 17:25:29 +05:30
expect_disallowed(*owner_permissions)
2017-08-17 22:00:37 +05:30
end
end
context 'owner' do
let(:current_user) { owner }
it do
2019-12-21 20:55:43 +05:30
expect_allowed(*read_group_permissions)
2018-03-17 18:26:18 +05:30
expect_allowed(*guest_permissions)
2017-09-10 17:25:29 +05:30
expect_allowed(*reporter_permissions)
2018-03-17 18:26:18 +05:30
expect_allowed(*developer_permissions)
2018-11-18 11:00:15 +05:30
expect_allowed(*maintainer_permissions)
2017-09-10 17:25:29 +05:30
expect_allowed(*owner_permissions)
2017-08-17 22:00:37 +05:30
end
end
end
2018-03-17 18:26:18 +05:30
describe 'change_share_with_group_lock' do
context 'when the current_user owns the group' do
let(:current_user) { owner }
context 'when the group share_with_group_lock is enabled' do
let(:group) { create(:group, share_with_group_lock: true, parent: parent) }
2019-12-21 20:55:43 +05:30
before do
group.add_owner(owner)
end
2018-03-17 18:26:18 +05:30
context 'when the parent group share_with_group_lock is enabled' do
context 'when the group has a grandparent' do
let(:parent) { create(:group, share_with_group_lock: true, parent: grandparent) }
context 'when the grandparent share_with_group_lock is enabled' do
let(:grandparent) { create(:group, share_with_group_lock: true) }
context 'when the current_user owns the parent' do
before do
parent.add_owner(current_user)
end
context 'when the current_user owns the grandparent' do
before do
grandparent.add_owner(current_user)
end
it { expect_allowed(:change_share_with_group_lock) }
end
context 'when the current_user does not own the grandparent' do
it { expect_disallowed(:change_share_with_group_lock) }
end
end
context 'when the current_user does not own the parent' do
it { expect_disallowed(:change_share_with_group_lock) }
end
end
context 'when the grandparent share_with_group_lock is disabled' do
let(:grandparent) { create(:group) }
context 'when the current_user owns the parent' do
before do
parent.add_owner(current_user)
end
it { expect_allowed(:change_share_with_group_lock) }
end
context 'when the current_user does not own the parent' do
it { expect_disallowed(:change_share_with_group_lock) }
end
end
end
context 'when the group does not have a grandparent' do
let(:parent) { create(:group, share_with_group_lock: true) }
context 'when the current_user owns the parent' do
before do
parent.add_owner(current_user)
end
it { expect_allowed(:change_share_with_group_lock) }
end
context 'when the current_user does not own the parent' do
it { expect_disallowed(:change_share_with_group_lock) }
end
end
end
context 'when the parent group share_with_group_lock is disabled' do
let(:parent) { create(:group) }
it { expect_allowed(:change_share_with_group_lock) }
end
end
context 'when the group share_with_group_lock is disabled' do
it { expect_allowed(:change_share_with_group_lock) }
end
end
context 'when the current_user does not own the group' do
let(:current_user) { create(:user) }
it { expect_disallowed(:change_share_with_group_lock) }
end
end
2019-02-15 15:39:39 +05:30
2019-10-31 01:37:42 +05:30
context 'transfer_projects' do
shared_examples_for 'allowed to transfer projects' do
before do
group.update(project_creation_level: project_creation_level)
end
it { is_expected.to be_allowed(:transfer_projects) }
end
shared_examples_for 'not allowed to transfer projects' do
before do
group.update(project_creation_level: project_creation_level)
end
it { is_expected.to be_disallowed(:transfer_projects) }
end
context 'reporter' do
let(:current_user) { reporter }
it_behaves_like 'not allowed to transfer projects' do
let(:project_creation_level) { ::Gitlab::Access::NO_ONE_PROJECT_ACCESS }
end
it_behaves_like 'not allowed to transfer projects' do
let(:project_creation_level) { ::Gitlab::Access::MAINTAINER_PROJECT_ACCESS }
end
it_behaves_like 'not allowed to transfer projects' do
let(:project_creation_level) { ::Gitlab::Access::DEVELOPER_MAINTAINER_PROJECT_ACCESS }
end
end
context 'developer' do
let(:current_user) { developer }
it_behaves_like 'not allowed to transfer projects' do
let(:project_creation_level) { ::Gitlab::Access::NO_ONE_PROJECT_ACCESS }
end
it_behaves_like 'not allowed to transfer projects' do
let(:project_creation_level) { ::Gitlab::Access::MAINTAINER_PROJECT_ACCESS }
end
it_behaves_like 'not allowed to transfer projects' do
let(:project_creation_level) { ::Gitlab::Access::DEVELOPER_MAINTAINER_PROJECT_ACCESS }
end
end
context 'maintainer' do
let(:current_user) { maintainer }
it_behaves_like 'not allowed to transfer projects' do
let(:project_creation_level) { ::Gitlab::Access::NO_ONE_PROJECT_ACCESS }
end
it_behaves_like 'allowed to transfer projects' do
let(:project_creation_level) { ::Gitlab::Access::MAINTAINER_PROJECT_ACCESS }
end
it_behaves_like 'allowed to transfer projects' do
let(:project_creation_level) { ::Gitlab::Access::DEVELOPER_MAINTAINER_PROJECT_ACCESS }
end
end
context 'owner' do
let(:current_user) { owner }
it_behaves_like 'not allowed to transfer projects' do
let(:project_creation_level) { ::Gitlab::Access::NO_ONE_PROJECT_ACCESS }
end
it_behaves_like 'allowed to transfer projects' do
let(:project_creation_level) { ::Gitlab::Access::MAINTAINER_PROJECT_ACCESS }
end
it_behaves_like 'allowed to transfer projects' do
let(:project_creation_level) { ::Gitlab::Access::DEVELOPER_MAINTAINER_PROJECT_ACCESS }
end
end
end
2020-03-13 15:44:24 +05:30
context 'create_projects' do
2019-07-07 11:18:12 +05:30
context 'when group has no project creation level set' do
2019-12-21 20:55:43 +05:30
before_all do
group.update(project_creation_level: nil)
end
2019-07-07 11:18:12 +05:30
context 'reporter' do
let(:current_user) { reporter }
it { is_expected.to be_disallowed(:create_projects) }
end
context 'developer' do
let(:current_user) { developer }
it { is_expected.to be_allowed(:create_projects) }
end
context 'maintainer' do
let(:current_user) { maintainer }
it { is_expected.to be_allowed(:create_projects) }
end
context 'owner' do
let(:current_user) { owner }
it { is_expected.to be_allowed(:create_projects) }
end
end
context 'when group has project creation level set to no one' do
2019-12-21 20:55:43 +05:30
before_all do
group.update(project_creation_level: ::Gitlab::Access::NO_ONE_PROJECT_ACCESS)
end
2019-07-07 11:18:12 +05:30
context 'reporter' do
let(:current_user) { reporter }
it { is_expected.to be_disallowed(:create_projects) }
end
context 'developer' do
let(:current_user) { developer }
it { is_expected.to be_disallowed(:create_projects) }
end
context 'maintainer' do
let(:current_user) { maintainer }
it { is_expected.to be_disallowed(:create_projects) }
end
context 'owner' do
let(:current_user) { owner }
it { is_expected.to be_disallowed(:create_projects) }
end
end
context 'when group has project creation level set to maintainer only' do
2019-12-21 20:55:43 +05:30
before_all do
group.update(project_creation_level: ::Gitlab::Access::MAINTAINER_PROJECT_ACCESS)
end
2019-07-07 11:18:12 +05:30
context 'reporter' do
let(:current_user) { reporter }
it { is_expected.to be_disallowed(:create_projects) }
end
context 'developer' do
let(:current_user) { developer }
it { is_expected.to be_disallowed(:create_projects) }
end
context 'maintainer' do
let(:current_user) { maintainer }
it { is_expected.to be_allowed(:create_projects) }
end
context 'owner' do
let(:current_user) { owner }
it { is_expected.to be_allowed(:create_projects) }
end
end
context 'when group has project creation level set to developers + maintainer' do
2019-12-21 20:55:43 +05:30
before_all do
group.update(project_creation_level: ::Gitlab::Access::DEVELOPER_MAINTAINER_PROJECT_ACCESS)
end
2019-07-07 11:18:12 +05:30
context 'reporter' do
let(:current_user) { reporter }
it { is_expected.to be_disallowed(:create_projects) }
end
context 'developer' do
let(:current_user) { developer }
it { is_expected.to be_allowed(:create_projects) }
end
context 'maintainer' do
let(:current_user) { maintainer }
it { is_expected.to be_allowed(:create_projects) }
end
context 'owner' do
let(:current_user) { owner }
it { is_expected.to be_allowed(:create_projects) }
end
end
end
2020-03-13 15:44:24 +05:30
context 'create_subgroup' do
2019-10-12 21:52:04 +05:30
context 'when group has subgroup creation level set to owner' do
2019-12-21 20:55:43 +05:30
before_all do
group.update(subgroup_creation_level: ::Gitlab::Access::OWNER_SUBGROUP_ACCESS)
2019-10-12 21:52:04 +05:30
end
context 'reporter' do
let(:current_user) { reporter }
it { is_expected.to be_disallowed(:create_subgroup) }
end
context 'developer' do
let(:current_user) { developer }
it { is_expected.to be_disallowed(:create_subgroup) }
end
context 'maintainer' do
let(:current_user) { maintainer }
it { is_expected.to be_disallowed(:create_subgroup) }
end
context 'owner' do
let(:current_user) { owner }
it { is_expected.to be_allowed(:create_subgroup) }
end
end
context 'when group has subgroup creation level set to maintainer' do
2019-12-21 20:55:43 +05:30
before_all do
group.update(subgroup_creation_level: ::Gitlab::Access::MAINTAINER_SUBGROUP_ACCESS)
2019-10-12 21:52:04 +05:30
end
context 'reporter' do
let(:current_user) { reporter }
it { is_expected.to be_disallowed(:create_subgroup) }
end
context 'developer' do
let(:current_user) { developer }
it { is_expected.to be_disallowed(:create_subgroup) }
end
context 'maintainer' do
let(:current_user) { maintainer }
it { is_expected.to be_allowed(:create_subgroup) }
end
context 'owner' do
let(:current_user) { owner }
it { is_expected.to be_allowed(:create_subgroup) }
end
end
end
2019-02-15 15:39:39 +05:30
it_behaves_like 'clusterable policies' do
let(:clusterable) { create(:group) }
let(:cluster) do
create(:cluster,
:provided_by_gcp,
:group,
groups: [clusterable])
end
end
2019-12-21 20:55:43 +05:30
describe 'update_max_artifacts_size' do
let(:group) { create(:group, :public) }
context 'when no user' do
let(:current_user) { nil }
it { expect_disallowed(:update_max_artifacts_size) }
end
context 'admin' do
let(:current_user) { admin }
it { expect_allowed(:update_max_artifacts_size) }
end
%w(guest reporter developer maintainer owner).each do |role|
context role do
let(:current_user) { send(role) }
it { expect_disallowed(:update_max_artifacts_size) }
end
end
end
2020-04-22 19:07:51 +05:30
it_behaves_like 'model with wiki policies' do
let(:container) { create(:group) }
def set_access_level(access_level)
allow(container).to receive(:wiki_access_level).and_return(access_level)
end
before do
stub_feature_flags(group_wiki: true)
end
context 'when the feature flag is disabled' do
before do
stub_feature_flags(group_wiki: false)
end
it 'does not include the wiki permissions' do
expect_disallowed(*permissions)
end
end
end
2017-08-17 22:00:37 +05:30
end