2019-11-21 07:06:40 -05:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'sidekiq/testing'
|
|
|
|
|
2020-04-21 11:21:10 -04:00
|
|
|
# rubocop:disable RSpec/ModifySidekiqMiddleware
|
|
|
|
module SidekiqMiddleware
|
|
|
|
def with_sidekiq_server_middleware(&block)
|
|
|
|
Sidekiq::Testing.server_middleware.clear
|
|
|
|
Sidekiq::Testing.server_middleware(&block)
|
|
|
|
ensure
|
|
|
|
Sidekiq::Testing.server_middleware.clear
|
|
|
|
end
|
|
|
|
end
|
|
|
|
# rubocop:enable RSpec/ModifySidekiqMiddleware
|
|
|
|
|
2019-11-21 07:06:40 -05:00
|
|
|
# If Sidekiq::Testing.inline! is used, SQL transactions done inside
|
|
|
|
# Sidekiq worker are included in the SQL query limit (in a real
|
|
|
|
# deployment sidekiq worker is executed separately). To avoid
|
|
|
|
# increasing SQL limit counter, the request is marked as whitelisted
|
|
|
|
# during Sidekiq block
|
|
|
|
class DisableQueryLimit
|
|
|
|
def call(worker_instance, msg, queue)
|
|
|
|
transaction = Gitlab::QueryLimiting::Transaction.current
|
|
|
|
|
|
|
|
if !transaction.respond_to?(:whitelisted) || transaction.whitelisted
|
|
|
|
yield
|
|
|
|
else
|
|
|
|
transaction.whitelisted = true
|
|
|
|
yield
|
|
|
|
transaction.whitelisted = false
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2020-04-24 08:10:16 -04:00
|
|
|
|
|
|
|
# When running `Sidekiq::Testing.inline!` each job is using a request-store.
|
|
|
|
# This middleware makes sure the values don't leak into eachother.
|
|
|
|
class IsolatedRequestStore
|
|
|
|
def call(_worker, msg, queue)
|
|
|
|
old_store = RequestStore.store.dup
|
|
|
|
RequestStore.clear!
|
|
|
|
|
|
|
|
yield
|
|
|
|
|
|
|
|
RequestStore.store = old_store
|
|
|
|
end
|
|
|
|
end
|