lib/active_record/railties/job_runtime.rb



# frozen_string_literal: true

require "active_record/runtime_registry"

module ActiveRecord
  module Railties # :nodoc:
    module JobRuntime # :nodoc:
      private
        def instrument(operation, payload = {}, &block)
          if operation == :perform && block
            super(operation, payload) do
              db_runtime_before_perform = ActiveRecord::RuntimeRegistry.sql_runtime
              result = block.call
              payload[:db_runtime] = ActiveRecord::RuntimeRegistry.sql_runtime - db_runtime_before_perform
              result
            end
          else
            super
          end
        end
    end
  end
end