summaryrefslogtreecommitdiff
path: root/lib/gitlab/metrics/sidekiq_middleware.rb
blob: ec10707d1fb17b037a8f42fd6d70e7180e2eada0 (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
module Gitlab
  module Metrics
    # Sidekiq middleware for tracking jobs.
    #
    # This middleware is intended to be used as a server-side middleware.
    class SidekiqMiddleware
      def call(worker, message, queue)
        # We don't want to track the MetricsWorker itself as otherwise we'll end
        # up in an infinite loop.
        if worker.class == MetricsWorker
          yield
          return
        end

        trans = Transaction.new

        begin
          trans.run { yield }
        ensure
          tag_worker(trans, worker)
          trans.finish
        end
      end

      def tag_worker(trans, worker)
        trans.add_tag(:action, "#{worker.class.name}#perform")
      end
    end
  end
end