Class: Buildkite::Trace::JobFinishedEvent
- Inherits:
-
Object
- Object
- Buildkite::Trace::JobFinishedEvent
- Defined in:
- lib/buildkite/trace/job_finished_event.rb
Overview
Value object that wraps raw buildkite webhook data and provides convenience methods for querying it
Instance Method Summary collapse
- #agent_hostname ⇒ Object
- #agent_name ⇒ Object
- #build_branch ⇒ Object
- #build_id ⇒ Object
-
#initialize(data) ⇒ JobFinishedEvent
constructor
A new instance of JobFinishedEvent.
- #job_finished_at ⇒ Object
- #job_id ⇒ Object
- #job_name ⇒ Object
- #job_slug ⇒ Object
- #job_started_at ⇒ Object
- #job_state ⇒ Object
- #job_web_url ⇒ Object
- #name ⇒ Object
- #pipeline_name ⇒ Object
- #pipeline_slug ⇒ Object
- #to_span ⇒ Object
Constructor Details
#initialize(data) ⇒ JobFinishedEvent
Returns a new instance of JobFinishedEvent.
10 11 12 |
# File 'lib/buildkite/trace/job_finished_event.rb', line 10 def initialize(data) @data = data end |
Instance Method Details
#agent_hostname ⇒ Object
52 53 54 |
# File 'lib/buildkite/trace/job_finished_event.rb', line 52 def agent_hostname @data.fetch("job", {}).fetch("agent",{}).fetch("hostname","") end |
#agent_name ⇒ Object
48 49 50 |
# File 'lib/buildkite/trace/job_finished_event.rb', line 48 def agent_name @data.fetch("job", {}).fetch("agent",{}).fetch("name","") end |
#build_branch ⇒ Object
60 61 62 |
# File 'lib/buildkite/trace/job_finished_event.rb', line 60 def build_branch @data.fetch("build", {}).fetch("branch","") end |
#build_id ⇒ Object
56 57 58 |
# File 'lib/buildkite/trace/job_finished_event.rb', line 56 def build_id @data.fetch("build", {}).fetch("id","") end |
#job_finished_at ⇒ Object
43 44 45 46 |
# File 'lib/buildkite/trace/job_finished_event.rb', line 43 def job_finished_at value = @data.fetch("job", {}).fetch("finished_at", nil) value ? DateTime.parse(value).to_time : nil end |
#job_id ⇒ Object
18 19 20 |
# File 'lib/buildkite/trace/job_finished_event.rb', line 18 def job_id @data.fetch("job", {}).fetch("id","") end |
#job_name ⇒ Object
22 23 24 |
# File 'lib/buildkite/trace/job_finished_event.rb', line 22 def job_name @data.fetch("job", {}).fetch("name","") end |
#job_slug ⇒ Object
26 27 28 |
# File 'lib/buildkite/trace/job_finished_event.rb', line 26 def job_slug slugorize(job_name) end |
#job_started_at ⇒ Object
38 39 40 41 |
# File 'lib/buildkite/trace/job_finished_event.rb', line 38 def job_started_at value = @data.fetch("job", {}).fetch("started_at", nil) value ? DateTime.parse(value).to_time : nil end |
#job_state ⇒ Object
30 31 32 |
# File 'lib/buildkite/trace/job_finished_event.rb', line 30 def job_state @data.fetch("job", {}).fetch("state","") end |
#job_web_url ⇒ Object
34 35 36 |
# File 'lib/buildkite/trace/job_finished_event.rb', line 34 def job_web_url @data.fetch("job", {}).fetch("web_url","") end |
#name ⇒ Object
14 15 16 |
# File 'lib/buildkite/trace/job_finished_event.rb', line 14 def name @data.fetch("event", "") end |
#pipeline_name ⇒ Object
64 65 66 |
# File 'lib/buildkite/trace/job_finished_event.rb', line 64 def pipeline_name @data.fetch("pipeline", {}).fetch("name", "") end |
#pipeline_slug ⇒ Object
68 69 70 |
# File 'lib/buildkite/trace/job_finished_event.rb', line 68 def pipeline_slug @data.fetch("pipeline", {}).fetch("slug", "") end |
#to_span ⇒ Object
72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 |
# File 'lib/buildkite/trace/job_finished_event.rb', line 72 def to_span Span.new( trace_id: Digest::CRC64.checksum(build_id), span_id: Digest::CRC64.checksum(job_id), parent_id: Digest::CRC64.checksum(build_id) + 1, name: "build.job", resource: job_name, service: "buildkite", type: "custom", start: job_started_at.to_i * 1_000_000_000, duration: duration_in_secs * 1_000_000_000, metrics: {_sampling_priority_v1: 2}, meta: {url: job_web_url, pipeline: pipeline_slug}, ) end |