Sha256: 37c6340a7bbe8e5cb58d9e9b90c9c12c7a87f76717454550fcbe724e987f5043

Contents?: true

Size: 1.61 KB

Versions: 17

Compression:

Stored size: 1.61 KB

Contents

require 'ddtrace/contrib/active_record/event'

module Datadog
  module Contrib
    module ActiveRecord
      module Events
        # Defines instrumentation for instantiation.active_record event
        module Instantiation
          include ActiveRecord::Event

          EVENT_NAME = 'instantiation.active_record'.freeze
          SPAN_NAME = 'active_record.instantiation'.freeze
          DEFAULT_SERVICE_NAME = 'active_record'.freeze

          module_function

          def supported?
            Gem.loaded_specs['activerecord'] \
              && Gem.loaded_specs['activerecord'].version >= Gem::Version.new('4.2')
          end

          def event_name
            self::EVENT_NAME
          end

          def span_name
            self::SPAN_NAME
          end

          def process(span, event, _id, payload)
            # Inherit service name from parent, if available.
            span.service = if configuration[:orm_service_name]
                             configuration[:orm_service_name]
                           elsif span.parent
                             span.parent.service
                           else
                             self::DEFAULT_SERVICE_NAME
                           end

            span.resource = payload.fetch(:class_name)
            span.span_type = 'custom'
            span.set_tag('active_record.instantiation.class_name', payload.fetch(:class_name))
            span.set_tag('active_record.instantiation.record_count', payload.fetch(:record_count))
          rescue StandardError => e
            Datadog::Tracer.log.debug(e.message)
          end
        end
      end
    end
  end
end

Version data entries

17 entries across 17 versions & 1 rubygems

Version Path
ddtrace-0.16.1 lib/ddtrace/contrib/active_record/events/instantiation.rb
ddtrace-0.15.0.internaltracinfeature1 lib/ddtrace/contrib/active_record/events/instantiation.rb
ddtrace-0.16.0 lib/ddtrace/contrib/active_record/events/instantiation.rb
ddtrace-0.14.2.disableprotocolversion4 lib/ddtrace/contrib/active_record/events/instantiation.rb
ddtrace-0.15.0 lib/ddtrace/contrib/active_record/events/instantiation.rb
ddtrace-0.14.2.withoutpriorityparsing1 lib/ddtrace/contrib/active_record/events/instantiation.rb
ddtrace-0.14.2 lib/ddtrace/contrib/active_record/events/instantiation.rb
ddtrace-0.14.1 lib/ddtrace/contrib/active_record/events/instantiation.rb
ddtrace-0.15.0.beta1 lib/ddtrace/contrib/active_record/events/instantiation.rb
ddtrace-0.14.0 lib/ddtrace/contrib/active_record/events/instantiation.rb
ddtrace-0.14.0.rc1 lib/ddtrace/contrib/active_record/events/instantiation.rb
ddtrace-0.13.2 lib/ddtrace/contrib/active_record/events/instantiation.rb
ddtrace-0.14.0.beta2 lib/ddtrace/contrib/active_record/events/instantiation.rb
ddtrace-0.14.0.beta1 lib/ddtrace/contrib/active_record/events/instantiation.rb
ddtrace-0.13.1 lib/ddtrace/contrib/active_record/events/instantiation.rb
ddtrace-0.13.0 lib/ddtrace/contrib/active_record/events/instantiation.rb
ddtrace-0.13.0.beta1 lib/ddtrace/contrib/active_record/events/instantiation.rb