Sha256: a2502918f5d21fa1532cebcd6a31b8638e884e012e5a5b09aa8224bc1b78a91b

Contents?: true

Size: 1.58 KB

Versions: 4

Compression:

Stored size: 1.58 KB

Contents

# frozen_string_literal: true

module SidekiqUniqueJobs
  #
  # Class MethodProfiler provides method level profiling
  #
  # @author Mikael Henriksson <mikael@mhenrixon.com>
  #
  class Profiler
    def self.patch(klass, methods, name) # rubocop:disable Metrics/MethodLength
      patches = methods.map do |method_name|
        <<~RUBY
          unless defined?(#{method_name}__mp_unpatched)
            alias_method :#{method_name}__mp_unpatched, :#{method_name}
            def #{method_name}(*args, &blk)
              unless prof = Thread.current[:_method_profiler]
                return #{method_name}__mp_unpatched(*args, &blk)
              end
              begin
                start = Process.clock_gettime(Process::CLOCK_MONOTONIC)
                #{method_name}__mp_unpatched(*args, &blk)
              ensure
                data = (prof[:#{name}] ||= {duration: 0.0, calls: 0})
                data[:duration] += Process.clock_gettime(Process::CLOCK_MONOTONIC) - start
                data[:calls] += 1
              end
            end
          end
        RUBY
      end.join("\n")

      klass.class_eval patches
    end

    def self.start
      Thread.current[:_method_profiler] = {
        __start: current_timestamp,
      }
    end

    def self.stop
      finish = current_timestamp
      return unless (data = Thread.current[:_method_profiler])

      Thread.current[:_method_profiler] = nil
      start = data.delete(:__start)
      data[:total_duration] = finish - start
      data
    end

    def self.current_timestamp
      Process.clock_gettime(Process::CLOCK_MONOTONIC)
    end
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
sidekiq-unique-jobs-7.0.0.beta29 lib/sidekiq_unique_jobs/profiler.rb
sidekiq-unique-jobs-7.0.0.beta28 lib/sidekiq_unique_jobs/profiler.rb
sidekiq-unique-jobs-7.0.0.beta27 lib/sidekiq_unique_jobs/profiler.rb
sidekiq-unique-jobs-7.0.0.beta26 lib/sidekiq_unique_jobs/profiler.rb