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>2021-04-12 21:12:15 +0300
committerGitLab Bot <gitlab-bot@gitlab.com>2021-04-12 21:12:15 +0300
commitda59ce8b217f67707b391d9fb3503dbdf8c4e511 (patch)
tree6839f806745e333f25ddb29317aead689cced15b /spec/workers/merge_requests
parent3df6bfc24c8877b9442d567378b8ebd8816cd443 (diff)
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'spec/workers/merge_requests')
-rw-r--r--spec/workers/merge_requests/assignees_change_worker_spec.rb12
-rw-r--r--spec/workers/merge_requests/handle_assignees_change_worker_spec.rb62
2 files changed, 68 insertions, 6 deletions
diff --git a/spec/workers/merge_requests/assignees_change_worker_spec.rb b/spec/workers/merge_requests/assignees_change_worker_spec.rb
index ccb0e5885ac..33478daf8d3 100644
--- a/spec/workers/merge_requests/assignees_change_worker_spec.rb
+++ b/spec/workers/merge_requests/assignees_change_worker_spec.rb
@@ -19,7 +19,7 @@ RSpec.describe MergeRequests::AssigneesChangeWorker do
describe '#perform' do
context 'with a non-existing merge request' do
it 'does nothing' do
- expect(::MergeRequests::UpdateAssigneesService).not_to receive(:new)
+ expect(::MergeRequests::HandleAssigneesChangeService).not_to receive(:new)
worker.perform(non_existing_record_id, user.id, user_ids)
end
@@ -27,7 +27,7 @@ RSpec.describe MergeRequests::AssigneesChangeWorker do
context 'with a non-existing user' do
it 'does nothing' do
- expect(::MergeRequests::UpdateAssigneesService).not_to receive(:new)
+ expect(::MergeRequests::HandleAssigneesChangeService).not_to receive(:new)
worker.perform(merge_request.id, non_existing_record_id, user_ids)
end
@@ -35,7 +35,7 @@ RSpec.describe MergeRequests::AssigneesChangeWorker do
context 'when there are no changes' do
it 'does nothing' do
- expect(::MergeRequests::UpdateAssigneesService).not_to receive(:new)
+ expect(::MergeRequests::HandleAssigneesChangeService).not_to receive(:new)
worker.perform(merge_request.id, user.id, merge_request.assignee_ids)
end
@@ -43,15 +43,15 @@ RSpec.describe MergeRequests::AssigneesChangeWorker do
context 'when the old users cannot be found' do
it 'does nothing' do
- expect(::MergeRequests::UpdateAssigneesService).not_to receive(:new)
+ expect(::MergeRequests::HandleAssigneesChangeService).not_to receive(:new)
worker.perform(merge_request.id, user.id, [non_existing_record_id])
end
end
it 'gets MergeRequests::UpdateAssigneesService to handle the changes' do
- expect_next(::MergeRequests::UpdateAssigneesService)
- .to receive(:handle_assignee_changes).with(merge_request, match_array(old_assignees))
+ expect_next(::MergeRequests::HandleAssigneesChangeService)
+ .to receive(:execute).with(merge_request, match_array(old_assignees), execute_hooks: true)
worker.perform(merge_request.id, user.id, user_ids)
end
diff --git a/spec/workers/merge_requests/handle_assignees_change_worker_spec.rb b/spec/workers/merge_requests/handle_assignees_change_worker_spec.rb
new file mode 100644
index 00000000000..43f5196c92f
--- /dev/null
+++ b/spec/workers/merge_requests/handle_assignees_change_worker_spec.rb
@@ -0,0 +1,62 @@
+# frozen_string_literal: true
+
+require 'spec_helper'
+
+RSpec.describe MergeRequests::HandleAssigneesChangeWorker do
+ include AfterNextHelpers
+
+ let_it_be(:merge_request) { create(:merge_request) }
+ let_it_be(:user) { create(:user) }
+ let_it_be(:old_assignees) { create_list(:user, 3) }
+
+ let(:user_ids) { old_assignees.map(&:id).to_a }
+ let(:options) { {} }
+ let(:worker) { described_class.new }
+
+ it_behaves_like 'an idempotent worker' do
+ let(:job_args) { [merge_request.id, user.id, user_ids, options] }
+ end
+
+ describe '#perform' do
+ it 'calls MergeRequests::HandleAssigneesChangeService#execute to handle the changes' do
+ expect_next(::MergeRequests::HandleAssigneesChangeService)
+ .to receive(:execute).with(merge_request, old_assignees, options)
+
+ worker.perform(merge_request.id, user.id, user_ids, options)
+ end
+
+ context 'when there are no changes' do
+ it 'still calls MergeRequests::HandleAssigneesChangeService#execute' do
+ expect_next(::MergeRequests::HandleAssigneesChangeService)
+ .to receive(:execute).with(merge_request, [], options)
+
+ worker.perform(merge_request.id, user.id, merge_request.assignee_ids, options)
+ end
+ end
+
+ context 'when the old assignees cannot be found' do
+ it 'still calls MergeRequests::HandleAssigneesChangeService#execute' do
+ expect_next(::MergeRequests::HandleAssigneesChangeService)
+ .to receive(:execute).with(merge_request, [], options)
+
+ worker.perform(merge_request.id, user.id, [non_existing_record_id], options)
+ end
+ end
+
+ context 'with a non-existing merge request' do
+ it 'does nothing' do
+ expect(::MergeRequests::HandleAssigneesChangeService).not_to receive(:new)
+
+ worker.perform(non_existing_record_id, user.id, user_ids, options)
+ end
+ end
+
+ context 'with a non-existing user' do
+ it 'does nothing' do
+ expect(::MergeRequests::HandleAssigneesChangeService).not_to receive(:new)
+
+ worker.perform(merge_request.id, non_existing_record_id, user_ids, options)
+ end
+ end
+ end
+end