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:
Diffstat (limited to 'spec/initializers/forbid_sidekiq_in_transactions_spec.rb')
-rw-r--r--spec/initializers/forbid_sidekiq_in_transactions_spec.rb57
1 files changed, 39 insertions, 18 deletions
diff --git a/spec/initializers/forbid_sidekiq_in_transactions_spec.rb b/spec/initializers/forbid_sidekiq_in_transactions_spec.rb
index 6cd15d37ad4..a89ac73f6fa 100644
--- a/spec/initializers/forbid_sidekiq_in_transactions_spec.rb
+++ b/spec/initializers/forbid_sidekiq_in_transactions_spec.rb
@@ -3,36 +3,57 @@
require 'spec_helper'
RSpec.describe 'Sidekiq::Worker' do
- let(:worker_class) do
- Class.new do
- include Sidekiq::Worker
+ shared_examples_for 'a forbiddable operation within a transaction' do
+ it 'allows the operation outside of a transaction' do
+ expect { operation }.not_to raise_error
+ end
- def perform
+ it 'forbids the operation within a transaction' do
+ ApplicationRecord.transaction do
+ expect { operation }.to raise_error(Sidekiq::Worker::EnqueueFromTransactionError)
end
end
- end
- it 'allows sidekiq worker outside of a transaction' do
- expect { worker_class.perform_async }.not_to raise_error
- end
+ it 'allows the oepration within a transaction if skipped' do
+ Sidekiq::Worker.skipping_transaction_check do
+ ApplicationRecord.transaction do
+ expect { operation }.not_to raise_error
+ end
+ end
+ end
- it 'forbids queue sidekiq worker in a transaction' do
- Project.transaction do
- expect { worker_class.perform_async }.to raise_error(Sidekiq::Worker::EnqueueFromTransactionError)
+ it 'forbids the operation if it is within a Ci::ApplicationRecord transaction' do
+ Ci::Pipeline.transaction do
+ expect { operation }.to raise_error(Sidekiq::Worker::EnqueueFromTransactionError)
+ end
end
end
- it 'allows sidekiq worker in a transaction if skipped' do
- Sidekiq::Worker.skipping_transaction_check do
- Project.transaction do
- expect { worker_class.perform_async }.not_to raise_error
+ context 'for sidekiq workers' do
+ let(:worker_class) do
+ Class.new do
+ include Sidekiq::Worker
+
+ def perform
+ end
end
end
+
+ let(:operation) { worker_class.perform_async }
+
+ it_behaves_like 'a forbiddable operation within a transaction'
end
- it 'forbids queue sidekiq worker in a Ci::ApplicationRecord transaction' do
- Ci::Pipeline.transaction do
- expect { worker_class.perform_async }.to raise_error(Sidekiq::Worker::EnqueueFromTransactionError)
+ context 'for mailers' do
+ let(:mailer_class) do
+ Class.new(ApplicationMailer) do
+ def test_mail
+ end
+ end
end
+
+ let(:operation) { mailer_class.test_mail.deliver_later }
+
+ it_behaves_like 'a forbiddable operation within a transaction'
end
end