Module: Datadog::Contrib::ActionView::Instrumentation::PartialRenderer

Included in:
RailsLessThan4
Defined in:
lib/ddtrace/contrib/action_view/instrumentation/partial_renderer.rb

Overview

Legacy instrumentation for partial rendering for Rails < 4

Defined Under Namespace

Modules: RailsLessThan4

Instance Method Summary collapse

Instance Method Details

#datadog_render_partial(template) ⇒ Object



32
33
34
35
36
37
38
39
40
41
42
43
44
45
# File 'lib/ddtrace/contrib/action_view/instrumentation/partial_renderer.rb', line 32

def datadog_render_partial(template)
  template_name = Utils.normalize_template_name(template.try('identifier'))

  if template_name
    active_datadog_span.resource = template_name
    active_datadog_span.set_tag(
      Ext::TAG_TEMPLATE_NAME,
      template_name
    )

    # Measure service stats
    Contrib::Analytics.set_measured(active_datadog_span)
  end
end

#render(*args, &block) ⇒ Object



10
11
12
13
14
15
16
17
# File 'lib/ddtrace/contrib/action_view/instrumentation/partial_renderer.rb', line 10

def render(*args, &block)
  datadog_tracer.trace(
    Ext::SPAN_RENDER_PARTIAL,
    span_type: Datadog::Ext::HTTP::TEMPLATE
  ) do |span|
    with_datadog_span(span) { super(*args) }
  end
end

#render_partial(*args) ⇒ Object



19
20
21
22
23
24
25
26
27
28
29
30
# File 'lib/ddtrace/contrib/action_view/instrumentation/partial_renderer.rb', line 19

def render_partial(*args)
  begin
    template = datadog_template(*args)

    datadog_render_partial(template)
  rescue StandardError => e
    Datadog.logger.debug(e.message)
  end

  # execute the original function anyway
  super(*args)
end