summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDouwe Maan <douwe@gitlab.com>2018-03-05 14:24:09 +0000
committerDouwe Maan <douwe@gitlab.com>2018-03-05 14:24:09 +0000
commit80cbaf539f313596c307d8e485df4f11afda31ba (patch)
treec4ebc8be4edacb2049f0180cf516b80cce7aa440
parent5a1da682a749314fae101d541fa030f326ad6980 (diff)
parent477c83f6bbbc9d0a447826900d45207e145e7261 (diff)
downloadgitlab-ce-80cbaf539f313596c307d8e485df4f11afda31ba.tar.gz
Merge branch 'backport-ee-5049-to-ce' into 'master'
Ports https://gitlab.com/gitlab-org/gitlab-ee/merge_requests/4747 to CE See merge request gitlab-org/gitlab-ce!17520
-rw-r--r--config/initializers/forbid_sidekiq_in_transactions.rb17
1 files changed, 15 insertions, 2 deletions
diff --git a/config/initializers/forbid_sidekiq_in_transactions.rb b/config/initializers/forbid_sidekiq_in_transactions.rb
index cb611aa21df..4cf1d455eb4 100644
--- a/config/initializers/forbid_sidekiq_in_transactions.rb
+++ b/config/initializers/forbid_sidekiq_in_transactions.rb
@@ -18,13 +18,26 @@ module Sidekiq
%i(perform_async perform_at perform_in).each do |name|
define_method(name) do |*args|
if !Sidekiq::Worker.skip_transaction_check && AfterCommitQueue.inside_transaction?
- raise Sidekiq::Worker::EnqueueFromTransactionError, <<~MSG
+ begin
+ raise Sidekiq::Worker::EnqueueFromTransactionError, <<~MSG
`#{self}.#{name}` cannot be called inside a transaction as this can lead to
race conditions when the worker runs before the transaction is committed and
tries to access a model that has not been saved yet.
Use an `after_commit` hook, or include `AfterCommitQueue` and use a `run_after_commit` block instead.
- MSG
+ MSG
+ rescue Sidekiq::Worker::EnqueueFromTransactionError => e
+ if Rails.env.production?
+ Rails.logger.error(e.message)
+
+ if Gitlab::Sentry.enabled?
+ Gitlab::Sentry.context
+ Raven.capture_exception(e)
+ end
+ else
+ raise
+ end
+ end
end
super(*args)