Sha256: 96bebbe638483ebb15d66d9661f949f2bf21f7f36694b8775557fa97cbb23f98

Contents?: true

Size: 1.43 KB

Versions: 4

Compression:

Stored size: 1.43 KB

Contents

# frozen_string_literal: true

require_relative '../../../metadata/ext'
require_relative '../../analytics'
require_relative '../ext'
require_relative '../event'

module Datadog
  module Tracing
    module Contrib
      module ActiveJob
        module Events
          # Defines instrumentation for retry_stopped.active_job event
          module RetryStopped
            include ActiveJob::Event

            EVENT_NAME = 'retry_stopped.active_job'

            module_function

            def event_name
              self::EVENT_NAME
            end

            def span_name
              Ext::SPAN_RETRY_STOPPED
            end

            def process(span, event, _id, payload)
              span.name = span_name
              span.service = configuration[:service_name] if configuration[:service_name]
              span.resource = payload[:job].class.name
              span.set_tag(Tracing::Metadata::Ext::TAG_OPERATION, Ext::TAG_OPERATION_RETRY_STOPPED)

              # Set analytics sample rate
              if Contrib::Analytics.enabled?(configuration[:analytics_enabled])
                Contrib::Analytics.set_sample_rate(span, configuration[:analytics_sample_rate])
              end

              set_common_tags(span, payload)
              span.set_tag(Ext::TAG_JOB_ERROR, payload[:error])
            rescue StandardError => e
              Datadog.logger.debug(e.message)
            end
          end
        end
      end
    end
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
datadog-2.1.0 lib/datadog/tracing/contrib/active_job/events/retry_stopped.rb
datadog-2.0.0 lib/datadog/tracing/contrib/active_job/events/retry_stopped.rb
datadog-2.0.0.beta2 lib/datadog/tracing/contrib/active_job/events/retry_stopped.rb
datadog-2.0.0.beta1 lib/datadog/tracing/contrib/active_job/events/retry_stopped.rb