debian-mirror-gitlab/spec/finders/groups/accepting_project_creations_finder_spec.rb
2023-07-09 08:55:56 +05:30

104 lines
4.1 KiB
Ruby

# frozen_string_literal: true
require 'spec_helper'
RSpec.describe Groups::AcceptingProjectCreationsFinder, feature_category: :subgroups do
let_it_be(:user) { create(:user) }
let_it_be(:group_where_direct_owner) { create(:group) }
let_it_be(:subgroup_of_group_where_direct_owner) { create(:group, parent: group_where_direct_owner) }
let_it_be(:group_where_direct_maintainer) { create(:group) }
let_it_be(:group_where_direct_maintainer_but_cant_create_projects) do
create(:group, project_creation_level: Gitlab::Access::NO_ONE_PROJECT_ACCESS)
end
let_it_be(:group_where_direct_developer_but_developers_cannot_create_projects) { create(:group) }
let_it_be(:group_where_direct_developer) do
create(:group, project_creation_level: Gitlab::Access::DEVELOPER_MAINTAINER_PROJECT_ACCESS)
end
let_it_be(:shared_with_group_where_direct_owner_as_owner) { create(:group) }
let_it_be(:shared_with_group_where_direct_owner_as_developer) do
create(:group, project_creation_level: Gitlab::Access::DEVELOPER_MAINTAINER_PROJECT_ACCESS)
end
let_it_be(:shared_with_group_where_direct_owner_as_developer_but_developers_cannot_create_projects) do
create(:group)
end
let_it_be(:shared_with_group_where_direct_developer_as_maintainer) do
create(:group, project_creation_level: Gitlab::Access::DEVELOPER_MAINTAINER_PROJECT_ACCESS)
end
let_it_be(:shared_with_group_where_direct_owner_as_guest) { create(:group) }
let_it_be(:shared_with_group_where_direct_owner_as_maintainer) { create(:group) }
let_it_be(:shared_with_group_where_direct_developer_as_owner) do
create(:group, project_creation_level: Gitlab::Access::DEVELOPER_MAINTAINER_PROJECT_ACCESS)
end
let_it_be(:subgroup_of_shared_with_group_where_direct_owner_as_maintainer) do
create(:group, parent: shared_with_group_where_direct_owner_as_maintainer)
end
before do
group_where_direct_owner.add_owner(user)
group_where_direct_maintainer.add_maintainer(user)
group_where_direct_developer_but_developers_cannot_create_projects.add_developer(user)
group_where_direct_developer.add_developer(user)
create(:group_group_link, :owner,
shared_with_group: group_where_direct_owner,
shared_group: shared_with_group_where_direct_owner_as_owner
)
create(:group_group_link, :developer,
shared_with_group: group_where_direct_owner,
shared_group: shared_with_group_where_direct_owner_as_developer_but_developers_cannot_create_projects
)
create(:group_group_link, :maintainer,
shared_with_group: group_where_direct_developer,
shared_group: shared_with_group_where_direct_developer_as_maintainer
)
create(:group_group_link, :developer,
shared_with_group: group_where_direct_owner,
shared_group: shared_with_group_where_direct_owner_as_developer
)
create(:group_group_link, :guest,
shared_with_group: group_where_direct_owner,
shared_group: shared_with_group_where_direct_owner_as_guest
)
create(:group_group_link, :maintainer,
shared_with_group: group_where_direct_owner,
shared_group: shared_with_group_where_direct_owner_as_maintainer
)
create(:group_group_link, :owner,
shared_with_group: group_where_direct_developer_but_developers_cannot_create_projects,
shared_group: shared_with_group_where_direct_developer_as_owner
)
end
describe '#execute' do
subject(:result) { described_class.new(user).execute }
it 'only returns groups where the user has access to create projects' do
expect(result).to match_array([
group_where_direct_owner,
subgroup_of_group_where_direct_owner,
group_where_direct_maintainer,
group_where_direct_developer,
# groups arising from group shares
shared_with_group_where_direct_owner_as_owner,
shared_with_group_where_direct_owner_as_maintainer,
subgroup_of_shared_with_group_where_direct_owner_as_maintainer,
shared_with_group_where_direct_developer_as_owner,
shared_with_group_where_direct_developer_as_maintainer,
shared_with_group_where_direct_owner_as_developer
])
end
end
end