Commit a6aa541a authored by Dan Davison's avatar Dan Davison

Merge branch 'update-pending-project-policy-specs' into 'master'

Update Project Policy Pending Membership Specs

See merge request gitlab-org/gitlab!81047
parents 654a47c8 5390b669
...@@ -1963,9 +1963,27 @@ RSpec.describe ProjectPolicy do ...@@ -1963,9 +1963,27 @@ RSpec.describe ProjectPolicy do
end end
describe 'pending member permissions' do describe 'pending member permissions' do
using RSpec::Parameterized::TableSyntax
let_it_be(:current_user) { create(:user) } let_it_be(:current_user) { create(:user) }
let_it_be(:group) { create(:group, :public) } let_it_be(:group) { create(:group, :public) }
context 'with a pending membership in a private project' do
let_it_be(:project) { create(:project, :private, public_builds: false) }
where(:role) do
Gitlab::Access.sym_options.keys.map(&:to_sym)
end
with_them do
it 'a pending member has permissions to the project as if the user is not a member' do
create(:project_member, :awaiting, role, source: project, user: current_user)
expect_private_project_permissions_as_if_non_member
end
end
end
context 'with a group invited to a project' do context 'with a group invited to a project' do
let_it_be(:project) { create(:project, :private, public_builds: false) } let_it_be(:project) { create(:project, :private, public_builds: false) }
...@@ -1973,10 +1991,16 @@ RSpec.describe ProjectPolicy do ...@@ -1973,10 +1991,16 @@ RSpec.describe ProjectPolicy do
create(:project_group_link, project: project, group: group) create(:project_group_link, project: project, group: group)
end end
it 'a pending developer in the group has permissions to the project as if the user is not a member' do where(:role) do
create(:group_member, :awaiting, :developer, source: group, user: current_user) Gitlab::Access.sym_options_with_owner.keys.map(&:to_sym)
end
with_them do
it 'a pending member in the group has permissions to the project as if the user is not a member' do
create(:group_member, :awaiting, role, source: group, user: current_user)
expect_private_project_permissions_as_if_non_member expect_private_project_permissions_as_if_non_member
end
end end
end end
...@@ -1988,10 +2012,16 @@ RSpec.describe ProjectPolicy do ...@@ -1988,10 +2012,16 @@ RSpec.describe ProjectPolicy do
create(:group_group_link, shared_with_group: group, shared_group: other_group) create(:group_group_link, shared_with_group: group, shared_group: other_group)
end end
it "a pending developer in the group has permissions to the other group's project as if the user is not a member" do where(:role) do
create(:group_member, :awaiting, :developer, source: group, user: current_user) Gitlab::Access.sym_options_with_owner.keys.map(&:to_sym)
end
with_them do
it "a pending member in the group has permissions to the other group's project as if the user is not a member" do
create(:group_member, :awaiting, role, source: group, user: current_user)
expect_private_project_permissions_as_if_non_member expect_private_project_permissions_as_if_non_member
end
end end
end end
...@@ -1999,10 +2029,16 @@ RSpec.describe ProjectPolicy do ...@@ -1999,10 +2029,16 @@ RSpec.describe ProjectPolicy do
let_it_be(:subgroup) { create(:group, :private, parent: group) } let_it_be(:subgroup) { create(:group, :private, parent: group) }
let_it_be(:project) { create(:project, :private, public_builds: false, namespace: subgroup) } let_it_be(:project) { create(:project, :private, public_builds: false, namespace: subgroup) }
it 'a pending developer in the group has permissions to the subgroup project as if the user is not a member' do where(:role) do
create(:group_member, :awaiting, :developer, source: group, user: current_user) Gitlab::Access.sym_options_with_owner.keys.map(&:to_sym)
end
with_them do
it 'a pending member in the group has permissions to the subgroup project as if the user is not a member' do
create(:group_member, :awaiting, role, source: group, user: current_user)
expect_private_project_permissions_as_if_non_member expect_private_project_permissions_as_if_non_member
end
end end
end end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment