Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGitLab Bot <gitlab-bot@gitlab.com>2020-03-26 18:08:16 +0300
committerGitLab Bot <gitlab-bot@gitlab.com>2020-03-26 18:08:16 +0300
commite80e0dd64fbb04f60394cb1bb08e17dbcb22b8ce (patch)
tree9e538341b9b77e96737964813e10235dbecf47ff /spec/models/member_spec.rb
parentef31adeb0fb9a02b2c6a4529ec4e38d7082a4b2b (diff)
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'spec/models/member_spec.rb')
-rw-r--r--spec/models/member_spec.rb100
1 files changed, 74 insertions, 26 deletions
diff --git a/spec/models/member_spec.rb b/spec/models/member_spec.rb
index ce3ee3fcfb0..13a0426624b 100644
--- a/spec/models/member_spec.rb
+++ b/spec/models/member_spec.rb
@@ -586,49 +586,97 @@ describe Member do
end
context 'when after_commit :update_highest_role' do
- where(:member_type, :source_type) do
- :project_member | :project
- :group_member | :group
- end
+ context 'with feature flag enabled' do
+ where(:member_type, :source_type) do
+ :project_member | :project
+ :group_member | :group
+ end
- with_them do
- describe 'create member' do
- it 'initializes a new Members::UpdateHighestRoleService object' do
- source = create(source_type) # source owner initializes a new service object too
- user = create(:user)
+ with_them do
+ describe 'create member' do
+ it 'initializes a new Members::UpdateHighestRoleService object' do
+ source = create(source_type) # source owner initializes a new service object too
+ user = create(:user)
- expect(Members::UpdateHighestRoleService).to receive(:new).with(user.id).and_call_original
+ expect(Members::UpdateHighestRoleService).to receive(:new).with(user.id).and_call_original
- create(member_type, :guest, user: user, source_type => source)
+ create(member_type, :guest, user: user, source_type => source)
+ end
end
- end
- context 'when member exists' do
- let!(:member) { create(member_type) }
+ context 'when member exists' do
+ let!(:member) { create(member_type) }
+
+ describe 'update member' do
+ context 'when access level was changed' do
+ it 'initializes a new Members::UpdateHighestRoleService object' do
+ expect(Members::UpdateHighestRoleService).to receive(:new).with(member.user_id).and_call_original
+
+ member.update(access_level: Gitlab::Access::GUEST)
+ end
+ end
+
+ context 'when access level was not changed' do
+ it 'does not initialize a new Members::UpdateHighestRoleService object' do
+ expect(Members::UpdateHighestRoleService).not_to receive(:new).with(member.user_id)
+
+ member.update(notification_level: NotificationSetting.levels[:disabled])
+ end
+ end
+ end
- describe 'update member' do
- context 'when access level was changed' do
+ describe 'destroy member' do
it 'initializes a new Members::UpdateHighestRoleService object' do
expect(Members::UpdateHighestRoleService).to receive(:new).with(member.user_id).and_call_original
- member.update(access_level: Gitlab::Access::GUEST)
+ member.destroy
end
end
+ end
+ end
+ end
- context 'when access level was not changed' do
- it 'does not initialize a new Members::UpdateHighestRoleService object' do
- expect(Members::UpdateHighestRoleService).not_to receive(:new).with(member.user_id)
+ context 'with feature flag disabled' do
+ before do
+ stub_feature_flags(highest_role_callback: false)
+ end
- member.update(notification_level: NotificationSetting.levels[:disabled])
- end
+ where(:member_type, :source_type) do
+ :project_member | :project
+ :group_member | :group
+ end
+
+ with_them do
+ describe 'create member' do
+ it 'does not initialize a new Members::UpdateHighestRoleService object' do
+ source = create(source_type)
+ user = create(:user)
+
+ expect(Members::UpdateHighestRoleService).not_to receive(:new).with(user.id)
+
+ create(member_type, :guest, user: user, source_type => source)
end
end
- describe 'destroy member' do
- it 'initializes a new Members::UpdateHighestRoleService object' do
- expect(Members::UpdateHighestRoleService).to receive(:new).with(member.user_id).and_call_original
+ context 'when member exists' do
+ let!(:member) { create(member_type) }
- member.destroy
+ describe 'update member' do
+ context 'when access level was changed' do
+ it 'does not initialize a new Members::UpdateHighestRoleService object' do
+ expect(Members::UpdateHighestRoleService).not_to receive(:new).with(member.user_id)
+
+ member.update(access_level: Gitlab::Access::GUEST)
+ end
+ end
+ end
+
+ describe 'destroy member' do
+ it 'does not initialize a new Members::UpdateHighestRoleService object' do
+ expect(Members::UpdateHighestRoleService).not_to receive(:new).with(member.user_id)
+
+ member.destroy
+ end
end
end
end