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 12:07:52 +0300
committerGitLab Bot <gitlab-bot@gitlab.com>2020-03-26 12:07:52 +0300
commit7e019504f5ac6decde690565857238e7e59aa034 (patch)
treefab8832b40e25fc9bc1ae54b9303b95ea146b5d5 /spec/services
parent116d4e56e83a1f408afe710ce070e699ba206475 (diff)
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'spec/services')
-rw-r--r--spec/services/members/update_highest_role_service_spec.rb42
-rw-r--r--spec/services/users/update_highest_member_role_service_spec.rb41
2 files changed, 83 insertions, 0 deletions
diff --git a/spec/services/members/update_highest_role_service_spec.rb b/spec/services/members/update_highest_role_service_spec.rb
new file mode 100644
index 00000000000..b56a51f83f9
--- /dev/null
+++ b/spec/services/members/update_highest_role_service_spec.rb
@@ -0,0 +1,42 @@
+# frozen_string_literal: true
+
+require 'spec_helper'
+require 'sidekiq/testing'
+
+describe Members::UpdateHighestRoleService, :clean_gitlab_redis_shared_state do
+ include ExclusiveLeaseHelpers
+
+ let_it_be(:user) { create(:user) }
+ let_it_be(:lease_key) { "update_highest_role:#{user.id}" }
+ let(:service) { described_class.new(user.id) }
+
+ describe '#perform' do
+ subject { service.execute }
+
+ context 'when lease is obtained' do
+ it 'takes the lease but does not release it', :aggregate_failures do
+ expect_to_obtain_exclusive_lease(lease_key, 'uuid', timeout: described_class::LEASE_TIMEOUT)
+
+ subject
+
+ expect(service.exclusive_lease.exists?).to be_truthy
+ end
+
+ it 'schedules a job' do
+ Sidekiq::Testing.fake! do
+ expect { subject }.to change(UpdateHighestRoleWorker.jobs, :size).by(1)
+ end
+ end
+ end
+
+ context 'when lease cannot be obtained' do
+ it 'only schedules one job' do
+ Sidekiq::Testing.fake! do
+ stub_exclusive_lease_taken(lease_key, timeout: described_class::LEASE_TIMEOUT)
+
+ expect { subject }.not_to change(UpdateHighestRoleWorker.jobs, :size)
+ end
+ end
+ end
+ end
+end
diff --git a/spec/services/users/update_highest_member_role_service_spec.rb b/spec/services/users/update_highest_member_role_service_spec.rb
new file mode 100644
index 00000000000..8063abffc2a
--- /dev/null
+++ b/spec/services/users/update_highest_member_role_service_spec.rb
@@ -0,0 +1,41 @@
+# frozen_string_literal: true
+
+require 'spec_helper'
+
+describe Users::UpdateHighestMemberRoleService do
+ let(:user) { create(:user) }
+ let(:execute_service) { described_class.new(user).execute }
+
+ describe '#execute' do
+ context 'when user_highest_role already exists' do
+ let!(:user_highest_role) { create(:user_highest_role, :guest, user: user) }
+
+ context 'when the current highest access level equals the already stored highest access level' do
+ it 'does not update the highest access level' do
+ create(:group_member, :guest, user: user)
+
+ expect { execute_service }.not_to change { user_highest_role.reload.highest_access_level }
+ end
+ end
+
+ context 'when the current highest access level does not equal the already stored highest access level' do
+ it 'updates the highest access level' do
+ create(:group_member, :developer, user: user)
+
+ expect { execute_service }
+ .to change { user_highest_role.reload.highest_access_level }
+ .from(Gitlab::Access::GUEST)
+ .to(Gitlab::Access::DEVELOPER)
+ end
+ end
+ end
+
+ context 'when user_highest_role does not exist' do
+ it 'creates an user_highest_role object to store the highest access level' do
+ create(:group_member, :guest, user: user)
+
+ expect { execute_service }.to change { UserHighestRole.count }.from(0).to(1)
+ end
+ end
+ end
+end