debian-mirror-gitlab/spec/services/members/groups/creator_service_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

44 lines
1.3 KiB
Ruby
Raw Normal View History

2021-09-30 23:02:18 +05:30
# frozen_string_literal: true
require 'spec_helper'
2023-05-27 22:25:52 +05:30
RSpec.describe Members::Groups::CreatorService, feature_category: :subgroups do
2022-07-23 23:45:48 +05:30
let_it_be(:source, reload: true) { create(:group, :public) }
2023-06-20 00:43:36 +05:30
let_it_be(:source2, reload: true) { create(:group, :public) }
2022-07-23 23:45:48 +05:30
let_it_be(:user) { create(:user) }
2021-09-30 23:02:18 +05:30
describe '.access_levels' do
it 'returns Gitlab::Access.options_with_owner' do
expect(described_class.access_levels).to eq(Gitlab::Access.sym_options_with_owner)
end
end
2022-07-16 23:28:13 +05:30
2022-07-23 23:45:48 +05:30
it_behaves_like 'owner management'
2022-08-13 15:12:31 +05:30
describe '.add_members' do
2022-07-23 23:45:48 +05:30
it_behaves_like 'bulk member creation' do
2023-06-20 00:43:36 +05:30
let_it_be(:source_type) { Group }
2022-07-23 23:45:48 +05:30
let_it_be(:member_type) { GroupMember }
end
end
2022-07-16 23:28:13 +05:30
2022-08-13 15:12:31 +05:30
describe '.add_member' do
2022-07-16 23:28:13 +05:30
it_behaves_like 'member creation' do
let_it_be(:member_type) { GroupMember }
end
context 'authorized projects update' do
it 'schedules a single project authorization update job when called multiple times' do
2022-08-27 11:52:29 +05:30
# this is inline with the overridden behaviour in stubbed_member.rb
worker_instance = AuthorizedProjectsWorker.new
expect(AuthorizedProjectsWorker).to receive(:new).once.and_return(worker_instance)
expect(worker_instance).to receive(:perform).with(user.id)
2022-07-16 23:28:13 +05:30
1.upto(3) do
2022-08-13 15:12:31 +05:30
described_class.add_member(source, user, :maintainer)
2022-07-16 23:28:13 +05:30
end
end
end
end
2021-09-30 23:02:18 +05:30
end