|
53 | 53 | expect(span).to_not have_error |
54 | 54 | expect(span.resource).to eq 'topic_a' |
55 | 55 | end |
| 56 | + |
| 57 | + context 'when the message has tracing headers' do |
| 58 | + let(:message) do |
| 59 | + headers = {} |
| 60 | + producer_trace = nil |
| 61 | + producer_span = nil |
| 62 | + Datadog::Tracing.trace('producer') do |span, trace| |
| 63 | + producer_span = span |
| 64 | + producer_trace = trace |
| 65 | + Datadog::Tracing::Contrib::Karafka.inject(trace.to_digest, headers) |
| 66 | + end |
| 67 | + metadata = ::Karafka::Messages::Metadata.new |
| 68 | + metadata['offset'] = 412 |
| 69 | + metadata[headers_accessor] = headers |
| 70 | + raw_payload = rand.to_s |
| 71 | + |
| 72 | + message = ::Karafka::Messages::Message.new(raw_payload, metadata) |
| 73 | + allow(message).to receive(:timestamp).and_return(Time.now) |
| 74 | + allow(message).to receive(:topic).and_return('topic_a') |
| 75 | + message |
| 76 | + end |
| 77 | + let(:headers_accessor) do |
| 78 | + ::Karafka::Messages::Metadata.members.include?(:raw_headers) ? 'raw_headers' : 'headers' |
| 79 | + end |
| 80 | + |
| 81 | + context 'when distributed tracing is enabled' do |
| 82 | + it 'continues the span that produced the message' do |
| 83 | + producer_trace_digest = Datadog::Tracing::Contrib::Karafka.extract(message.metadata[headers_accessor]) |
| 84 | + |
| 85 | + consumer_span = nil |
| 86 | + consumer_trace = nil |
| 87 | + |
| 88 | + Datadog::Tracing.trace('consumer') do |
| 89 | + consumer_span = Datadog::Tracing.active_span |
| 90 | + consumer_trace = Datadog::Tracing.active_trace |
| 91 | + |
| 92 | + topic = ::Karafka::Routing::Topic.new('topic_a', double(id: 0)) |
| 93 | + messages = ::Karafka::Messages::Builders::Messages.call([message], topic, 0, Time.now) |
| 94 | + expect(messages).to all(be_a(::Karafka::Messages::Message)) |
| 95 | + |
| 96 | + # assert that the current trace re-set to the original trace after iterating the messages |
| 97 | + expect(Datadog::Tracing.active_trace).to eq(consumer_trace) |
| 98 | + expect(Datadog::Tracing.active_span).to eq(consumer_span) |
| 99 | + end |
| 100 | + |
| 101 | + expect(spans).to have(3).items |
| 102 | + |
| 103 | + # assert that the message span is a continuation of the producer span |
| 104 | + expect(span.parent_id).to eq producer_trace_digest.span_id |
| 105 | + expect(span.trace_id).to eq producer_trace_digest.trace_id |
| 106 | + |
| 107 | + expect(span.links.map { |l| [l.trace_id, l.span_id] }).to contain_exactly( |
| 108 | + [consumer_trace.id, consumer_span.id] |
| 109 | + ) |
| 110 | + expect(consumer_span.links.map { |l| [l.trace_id, l.span_id] }).to contain_exactly( |
| 111 | + [span.trace_id, span.id] |
| 112 | + ) |
| 113 | + end |
| 114 | + end |
| 115 | + |
| 116 | + context 'when distributed tracing is not enabled' do |
| 117 | + let(:configuration_options) { { distributed_tracing: false } } |
| 118 | + |
| 119 | + it 'does not continue the span that produced the message' do |
| 120 | + consumer_span = nil |
| 121 | + consumer_trace = nil |
| 122 | + |
| 123 | + Datadog::Tracing.trace('consumer') do |
| 124 | + consumer_span = Datadog::Tracing.active_span |
| 125 | + consumer_trace = Datadog::Tracing.active_trace |
| 126 | + |
| 127 | + topic = ::Karafka::Routing::Topic.new('topic_a', double(id: 0)) |
| 128 | + messages = ::Karafka::Messages::Builders::Messages.call([message], topic, 0, Time.now) |
| 129 | + expect(messages).to all(be_a(::Karafka::Messages::Message)) |
| 130 | + |
| 131 | + # assert that the current trace re-set to the original trace after iterating the messages |
| 132 | + expect(Datadog::Tracing.active_trace).to eq(consumer_trace) |
| 133 | + expect(Datadog::Tracing.active_span).to eq(consumer_span) |
| 134 | + end |
| 135 | + |
| 136 | + expect(spans).to have(3).items |
| 137 | + |
| 138 | + # assert that the message span is not continuation of the producer span |
| 139 | + expect(span.parent_id).to eq(consumer_span.id) |
| 140 | + expect(span.trace_id).to eq(consumer_trace.id) |
| 141 | + |
| 142 | + expect(span.links).to be_empty |
| 143 | + expect(consumer_span.links).to be_empty |
| 144 | + end |
| 145 | + end |
| 146 | + end |
56 | 147 | end |
57 | 148 |
|
58 | 149 | describe 'worker.processed' do |
|
0 commit comments