Module: Datadog::Tracing::Contrib::ActiveSupport::Cache::Instrumentation::Read

Defined in:
lib/datadog/tracing/contrib/active_support/cache/instrumentation.rb

Overview

Defines instrumentation for ActiveSupport cache reading

Instance Method Summary collapse

Instance Method Details

#read(*args, &block) ⇒ Object



112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
# File 'lib/datadog/tracing/contrib/active_support/cache/instrumentation.rb', line 112

def read(*args, &block)
  payload = {
    action: Ext::RESOURCE_CACHE_GET,
    key: args[0],
    tracing_context: {}
  }

  begin
    # process and catch cache exceptions
    Instrumentation.start_trace_cache(payload)
    super
  rescue Exception => e
    payload[:exception] = [e.class.name, e.message]
    payload[:exception_object] = e
    raise e
  end
ensure
  Instrumentation.finish_trace_cache(payload)
end