Welcome to mirror list, hosted at ThFree Co, Russian Federation.

sidekiq_middleware.rb « support « spec - gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 73f43487d7cd6afe95d70ba290efd95edbe4eebe (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
# frozen_string_literal: true

require 'sidekiq/testing'

# rubocop:disable RSpec/ModifySidekiqMiddleware
module SidekiqMiddleware
  def with_sidekiq_server_middleware(&block)
    Sidekiq::Testing.server_middleware.clear

    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)

    Sidekiq::Testing.server_middleware(&block)
  ensure
    Sidekiq::Testing.server_middleware.clear
  end
end
# rubocop:enable RSpec/ModifySidekiqMiddleware

# 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, query limiting is disabled during Sidekiq block
class DisableQueryLimit
  def call(worker_instance, msg, queue)
    ::Gitlab::QueryLimiting.disable!('https://mock-issue')
    yield
  ensure
    ::Gitlab::QueryLimiting.enable!
  end
end

# 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