Sha256: ef71f281f6efc18e93021e392111e25514ea89a6c9ba0f1a41334d49413d18ce

Contents?: true

Size: 1.15 KB

Versions: 9

Compression:

Stored size: 1.15 KB

Contents

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

        lifecycle.after(:execute) do |execute|
          Appsignal.stop
        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,
          :metadata => {
            :id       => job.id,
            :queue    => job.queue,
            :priority => job.priority || 0,
            :attempts => job.attempts || 0
          },
          :queue_start => job.created_at
        ) do
          block.call(job)
        end
      end
    end
  end
end

Version data entries

9 entries across 9 versions & 1 rubygems

Version Path
appsignal-1.0.3.beta.2 lib/appsignal/integrations/delayed_job_plugin.rb
appsignal-1.0.3.beta.1 lib/appsignal/integrations/delayed_job_plugin.rb
appsignal-1.0.2 lib/appsignal/integrations/delayed_job_plugin.rb
appsignal-1.0.2.beta.4 lib/appsignal/integrations/delayed_job_plugin.rb
appsignal-1.0.2.beta.3 lib/appsignal/integrations/delayed_job_plugin.rb
appsignal-1.0.2.beta.2 lib/appsignal/integrations/delayed_job_plugin.rb
appsignal-1.0.2.beta.1 lib/appsignal/integrations/delayed_job_plugin.rb
appsignal-1.0.1 lib/appsignal/integrations/delayed_job_plugin.rb
appsignal-1.0.0 lib/appsignal/integrations/delayed_job_plugin.rb