1
0
Fork 0
mirror of https://github.com/rails/rails.git synced 2022-11-09 12:12:34 -05:00
rails--rails/activejob/lib/active_job/instrumentation.rb

25 lines
619 B
Ruby
Raw Normal View History

2019-09-23 12:29:52 -04:00
# frozen_string_literal: true
module ActiveJob
module Instrumentation #:nodoc:
extend ActiveSupport::Concern
included do
around_enqueue do |_, block|
scheduled_at ? instrument(:enqueue_at, &block) : instrument(:enqueue, &block)
2019-09-23 12:29:52 -04:00
end
around_perform do |_, block|
instrument :perform_start
instrument :perform, &block
2019-09-23 12:29:52 -04:00
end
end
private
def instrument(operation, payload = {}, &block)
ActiveSupport::Notifications.instrument \
"#{operation}.active_job", payload.merge(adapter: queue_adapter, job: self), &block
end
2019-09-23 12:29:52 -04:00
end
end