debian-mirror-gitlab/spec/support/sidekiq_middleware.rb

50 lines
1.5 KiB
Ruby
Raw Normal View History

2020-01-01 13:55:28 +05:30
# frozen_string_literal: true
require 'sidekiq/testing'
2020-04-22 19:07:51 +05:30
# rubocop:disable RSpec/ModifySidekiqMiddleware
module SidekiqMiddleware
def with_sidekiq_server_middleware(&block)
Sidekiq::Testing.server_middleware.clear
2023-01-13 00:05:48 +05:30
if Gem::Version.new(Sidekiq::VERSION) != Gem::Version.new('6.5.7')
raise 'New version of sidekiq detected, please remove this line'
end
# This line is a workaround for a Sidekiq bug that is already fixed in v7.0.0
# https://github.com/mperham/sidekiq/commit/1b83a152786ed382f07fff12d2608534f1e3c922
Sidekiq::Testing.server_middleware.instance_variable_set(:@config, Sidekiq)
2020-04-22 19:07:51 +05:30
Sidekiq::Testing.server_middleware(&block)
ensure
Sidekiq::Testing.server_middleware.clear
end
end
# rubocop:enable RSpec/ModifySidekiqMiddleware
2020-01-01 13:55:28 +05:30
# If Sidekiq::Testing.inline! is used, SQL transactions done inside
# Sidekiq worker are included in the SQL query limit (in a real
2021-04-29 21:17:54 +05:30
# deployment sidekiq worker is executed separately). To avoid increasing
# SQL limit counter, query limiting is disabled during Sidekiq block
2020-01-01 13:55:28 +05:30
class DisableQueryLimit
def call(worker_instance, msg, queue)
2021-04-29 21:17:54 +05:30
::Gitlab::QueryLimiting.disable!('https://mock-issue')
yield
ensure
::Gitlab::QueryLimiting.enable!
2020-01-01 13:55:28 +05:30
end
end
2020-05-24 23:13:21 +05:30
# 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