Class: InfluxReporter::Transaction
- Inherits:
-
Object
- Object
- InfluxReporter::Transaction
- Defined in:
- lib/influx_reporter/transaction.rb
Constant Summary collapse
- ROOT_TRACE_NAME =
'transaction'
Instance Attribute Summary collapse
-
#config ⇒ Object
readonly
Returns the value of attribute config.
-
#duration ⇒ Object
Returns the value of attribute duration.
-
#endpoint ⇒ Object
Returns the value of attribute endpoint.
-
#kind ⇒ Object
Returns the value of attribute kind.
-
#notifications ⇒ Object
readonly
Returns the value of attribute notifications.
-
#result ⇒ Object
Returns the value of attribute result.
-
#root_trace ⇒ Object
readonly
Returns the value of attribute root_trace.
-
#start_time ⇒ Object
readonly
Returns the value of attribute start_time.
-
#timestamp ⇒ Object
readonly
Returns the value of attribute timestamp.
-
#traces ⇒ Object
readonly
Returns the value of attribute traces.
Instance Method Summary collapse
- #_trace_started(trace) ⇒ Object
- #_trace_stopped(trace) ⇒ Object
- #current_offset ⇒ Object
- #current_trace ⇒ Object
- #done(result = nil) ⇒ Object
- #done? ⇒ Boolean
- #extra_tags {|| ... } ⇒ Object
- #extra_values {|| ... } ⇒ Object
-
#initialize(client, endpoint, kind = 'code.custom', result = nil) ⇒ Transaction
constructor
A new instance of Transaction.
- #inspect ⇒ Object
- #release ⇒ Object
- #running_traces ⇒ Object
- #submit(result = nil) ⇒ Object
- #trace(signature, kind = nil, extra = nil) ⇒ Object
Constructor Details
#initialize(client, endpoint, kind = 'code.custom', result = nil) ⇒ Transaction
Returns a new instance of Transaction.
13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 |
# File 'lib/influx_reporter/transaction.rb', line 13 def initialize(client, endpoint, kind = 'code.custom', result = nil) @client = client @config = client.config if client.respond_to?(:config) @endpoint = endpoint @kind = kind @result = result @timestamp = Util.nanos @running_traces = [] @root_trace = Trace.new(self, ROOT_TRACE_NAME, ROOT_TRACE_NAME) @traces = [@root_trace] @notifications = [] @start_time = Util.nanos @root_trace.start @start_time end |
Instance Attribute Details
#config ⇒ Object (readonly)
Returns the value of attribute config.
32 33 34 |
# File 'lib/influx_reporter/transaction.rb', line 32 def config @config end |
#duration ⇒ Object
Returns the value of attribute duration.
31 32 33 |
# File 'lib/influx_reporter/transaction.rb', line 31 def duration @duration end |
#endpoint ⇒ Object
Returns the value of attribute endpoint.
31 32 33 |
# File 'lib/influx_reporter/transaction.rb', line 31 def endpoint @endpoint end |
#kind ⇒ Object
Returns the value of attribute kind.
31 32 33 |
# File 'lib/influx_reporter/transaction.rb', line 31 def kind @kind end |
#notifications ⇒ Object (readonly)
Returns the value of attribute notifications.
32 33 34 |
# File 'lib/influx_reporter/transaction.rb', line 32 def notifications @notifications end |
#result ⇒ Object
Returns the value of attribute result.
31 32 33 |
# File 'lib/influx_reporter/transaction.rb', line 31 def result @result end |
#root_trace ⇒ Object (readonly)
Returns the value of attribute root_trace.
32 33 34 |
# File 'lib/influx_reporter/transaction.rb', line 32 def root_trace @root_trace end |
#start_time ⇒ Object (readonly)
Returns the value of attribute start_time.
32 33 34 |
# File 'lib/influx_reporter/transaction.rb', line 32 def start_time @start_time end |
#timestamp ⇒ Object (readonly)
Returns the value of attribute timestamp.
32 33 34 |
# File 'lib/influx_reporter/transaction.rb', line 32 def @timestamp end |
#traces ⇒ Object (readonly)
Returns the value of attribute traces.
32 33 34 |
# File 'lib/influx_reporter/transaction.rb', line 32 def traces @traces end |
Instance Method Details
#_trace_started(trace) ⇒ Object
81 82 83 |
# File 'lib/influx_reporter/transaction.rb', line 81 def _trace_started(trace) @running_traces.push trace end |
#_trace_stopped(trace) ⇒ Object
85 86 87 88 89 90 91 |
# File 'lib/influx_reporter/transaction.rb', line 85 def _trace_stopped(trace) if @running_traces.last == trace @running_traces.pop else @running_traces.delete trace end end |
#current_offset ⇒ Object
111 112 113 114 115 116 117 |
# File 'lib/influx_reporter/transaction.rb', line 111 def current_offset if curr = current_trace return curr.start_time end start_time end |
#current_trace ⇒ Object
107 108 109 |
# File 'lib/influx_reporter/transaction.rb', line 107 def current_trace @running_traces.last end |
#done(result = nil) ⇒ Object
38 39 40 41 42 43 44 45 |
# File 'lib/influx_reporter/transaction.rb', line 38 def done(result = nil) @result = result @root_trace.done Util.nanos @duration = @root_trace.duration self end |
#done? ⇒ Boolean
47 48 49 |
# File 'lib/influx_reporter/transaction.rb', line 47 def done? @root_trace.done? end |
#extra_tags {|| ... } ⇒ Object
93 94 95 96 |
# File 'lib/influx_reporter/transaction.rb', line 93 def @root_trace.extra[:tags] ||= {} yield @root_trace.extra[:tags] end |
#extra_values {|| ... } ⇒ Object
98 99 100 101 |
# File 'lib/influx_reporter/transaction.rb', line 98 def extra_values @root_trace.extra[:values] ||= {} yield @root_trace.extra[:values] end |
#inspect ⇒ Object
119 120 121 122 123 124 125 |
# File 'lib/influx_reporter/transaction.rb', line 119 def inspect info = %w[endpoint kind result duration timestamp start_time] <<~TEXT <Transaction #{info.map { |m| "#{m}:#{send(m).inspect}" }.join(' ')}> #{traces.map(&:inspect).join("\n ")}" TEXT end |
#release ⇒ Object
34 35 36 |
# File 'lib/influx_reporter/transaction.rb', line 34 def release @client.current_transaction = nil end |
#running_traces ⇒ Object
103 104 105 |
# File 'lib/influx_reporter/transaction.rb', line 103 def running_traces @running_traces.clone end |
#submit(result = nil) ⇒ Object
51 52 53 54 55 56 57 58 59 |
# File 'lib/influx_reporter/transaction.rb', line 51 def submit(result = nil) done result release @client.submit_transaction self self end |
#trace(signature, kind = nil, extra = nil) ⇒ Object
61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 |
# File 'lib/influx_reporter/transaction.rb', line 61 def trace(signature, kind = nil, extra = nil) trace = Trace.new(self, signature, kind, running_traces, extra) rel_time = current_offset traces << trace trace.start rel_time return trace unless block_given? begin result = yield trace ensure trace.done end result end |