Sha256: a336f655c5013eba658008104c3d4c7fdc2c7cdc6c2fc63feb1d2b208cda04ee

Contents?: true

Size: 1.98 KB

Versions: 2

Compression:

Stored size: 1.98 KB

Contents

require_relative '../../metadata/ext'
require_relative '../active_support/notifications/event'
require_relative 'ext'

module Datadog
  module Tracing
    module Contrib
      module ActiveJob
        # Defines basic behaviors for an ActiveJob event.
        module Event
          def self.included(base)
            base.include(ActiveSupport::Notifications::Event)
            base.extend(ClassMethods)
          end

          # Class methods for ActiveJob events.
          module ClassMethods
            def span_options
              options = {}
              options[:service] = configuration[:service_name] if configuration[:service_name]
              options
            end

            def configuration
              Datadog.configuration.tracing[:active_job]
            end

            def set_common_tags(span, payload)
              adapter_name = if payload[:adapter].is_a?(Class)
                               payload[:adapter].name
                             else
                               payload[:adapter].class.name
                             end
              span.set_tag(Ext::TAG_ADAPTER, adapter_name)

              span.set_tag(Tracing::Metadata::Ext::TAG_COMPONENT, Ext::TAG_COMPONENT)

              job = payload[:job]
              span.set_tag(Ext::TAG_JOB_ID, job.job_id)
              span.set_tag(Ext::TAG_JOB_QUEUE, job.queue_name)
              span.set_tag(Ext::TAG_JOB_PRIORITY, job.priority) if job.respond_to?(:priority)
              span.set_tag(Ext::TAG_JOB_EXECUTIONS, job.executions) if job.respond_to?(:executions)

              job_scheduled_at = if job.respond_to?(:scheduled_at)
                                   job.scheduled_at
                                 elsif job.respond_to?(:enqueued_at)
                                   job.enqueued_at
                                 end
              span.set_tag(Ext::TAG_JOB_SCHEDULED_AT, Time.at(job_scheduled_at)) if job_scheduled_at
            end
          end
        end
      end
    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
ddtrace-1.10.1 lib/datadog/tracing/contrib/active_job/event.rb
ddtrace-1.10.0 lib/datadog/tracing/contrib/active_job/event.rb