summaryrefslogtreecommitdiff
path: root/lib/gitlab/sidekiq_middleware/instrumentation_logger.rb
blob: 979a3fce7e67dc04747db4937e5bce64f6c561f8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
# frozen_string_literal: true

module Gitlab
  module SidekiqMiddleware
    class InstrumentationLogger
      def call(worker, job, queue)
        yield

        # The Sidekiq logger is called outside the middleware block, so
        # we need to modify the job hash to pass along this information
        # since RequestStore is only active in the Sidekiq middleware.
        #
        # Modifying the job hash in a middleware is permitted by Sidekiq
        # because Sidekiq keeps a pristine copy of the original hash
        # before sending it to the middleware:
        # https://github.com/mperham/sidekiq/blob/53bd529a0c3f901879925b8390353129c465b1f2/lib/sidekiq/processor.rb#L115-L118
        ::Gitlab::InstrumentationHelper.add_instrumentation_data(job)
      end
    end
  end
end