Sha256: 9372a4df5b0da87be5c91561145c8541759b81b6b12bd3cd4af2e1eeacf27509

Contents?: true

Size: 1.1 KB

Versions: 3

Compression:

Stored size: 1.1 KB

Contents

if defined?(::Delayed::Plugin)
  Appsignal.logger.info('Loading Delayed Job integration')

  module Appsignal
    module Integrations
      class DelayedPlugin < ::Delayed::Plugin
        callbacks do |lifecycle|
          lifecycle.around(:invoke_job) do |job, &block|
            invoke_with_instrumentation(job, block)
          end
        end

        def self.invoke_with_instrumentation(job, block)
          class_and_method_name = if job.payload_object.respond_to?(:appsignal_name)
            job.payload_object.appsignal_name
          else
            job.name
          end
          class_name, method_name = class_and_method_name.split('#')

          Appsignal.monitor_transaction(
            'perform_job.delayed_job',
            :class => class_name,
            :method => method_name,
            :priority => job.priority,
            :attempts => job.attempts,
            :queue => job.queue,
            :queue_start => job.created_at
          ) do
            block.call(job)
          end
        end
      end
    end
  end
  ::Delayed::Worker.plugins << Appsignal::Integrations::DelayedPlugin
end

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
appsignal-0.11.8.beta.0 lib/appsignal/integrations/delayed_job.rb
appsignal-0.11.7 lib/appsignal/integrations/delayed_job.rb
appsignal-0.11.7.beta.1 lib/appsignal/integrations/delayed_job.rb