Class: NewRelic::Agent::Instrumentation::ActionViewSubscriber::RenderEvent

Inherits:
Event
  • Object
show all
Defined in:
lib/new_relic/agent/instrumentation/action_view_subscriber.rb

Instance Attribute Summary

Attributes inherited from Event

#children, #end, #name, #parent, #payload, #scope, #time, #transaction_id

Instance Method Summary collapse

Methods inherited from Event

#<<, #duration, #initialize, #parent_of?

Constructor Details

This class inherits a constructor from NewRelic::Agent::Instrumentation::Event

Instance Method Details

#metric_action(name) ⇒ Object



77
78
79
80
81
82
83
# File 'lib/new_relic/agent/instrumentation/action_view_subscriber.rb', line 77

def metric_action(name)
  case name
  when /render_template.action_view$/  then 'Rendering'
  when 'render_partial.action_view'    then 'Partial'
  when 'render_collection.action_view' then 'Partial'
  end
end

#metric_nameObject



50
51
52
53
54
55
56
57
58
59
60
61
62
63
# File 'lib/new_relic/agent/instrumentation/action_view_subscriber.rb', line 50

def metric_name
  if parent && (payload[:virtual_path] ||
                (parent.payload[:identifier] =~ /template$/))
    return parent.metric_name
  elsif payload.key?(:virtual_path)
    identifier = payload[:virtual_path]
  else
    identifier = payload[:identifier]
  end

  # memoize
  @metric_name ||= "View/#{metric_path(identifier)}/#{metric_action(name)}"
  @metric_name
end

#metric_path(identifier) ⇒ Object



65
66
67
68
69
70
71
72
73
74
75
# File 'lib/new_relic/agent/instrumentation/action_view_subscriber.rb', line 65

def metric_path(identifier)
  if identifier == nil
    'file'
  elsif identifier =~ /template$/
    identifier
  elsif (parts = identifier.split('/')).size > 1
    parts[-2..-1].join('/')
  else
    ::NewRelic::Agent::UNKNOWN_METRIC
  end
end

#recordable?Boolean

Nearly every “render_blah.action_view” event has a child in the form of “!render_blah.action_view”. The children are the ones we want to record. There are a couple special cases of events without children.

Returns:

  • (Boolean)


44
45
46
47
48
# File 'lib/new_relic/agent/instrumentation/action_view_subscriber.rb', line 44

def recordable?
  name[0] == '!' ||
    metric_name == 'View/text template/Rendering' ||
    metric_name == "View/#{::NewRelic::Agent::UNKNOWN_METRIC}/Partial"
end