Skip to content

Commit

Permalink
[net/http] Use HTTPPropagator.inject! instead of req.add_field (#768)
Browse files Browse the repository at this point in the history
* [net/http] Use HTTPPropagator.inject! instead of req.add_field

* ensure we are comparing strings to strings
  • Loading branch information
brettlangdon authored Jun 27, 2019
1 parent fd39995 commit 1a9ff12
Show file tree
Hide file tree
Showing 2 changed files with 47 additions and 9 deletions.
9 changes: 1 addition & 8 deletions lib/ddtrace/contrib/http/instrumentation.rb
Original file line number Diff line number Diff line change
Expand Up @@ -67,14 +67,7 @@ def request(req, body = nil, &block) # :yield: +response+
span.resource = req.method

if pin.tracer.enabled && !Datadog::Contrib::HTTP.should_skip_distributed_tracing?(pin)
req.add_field(Datadog::Ext::DistributedTracing::HTTP_HEADER_TRACE_ID, span.trace_id)
req.add_field(Datadog::Ext::DistributedTracing::HTTP_HEADER_PARENT_ID, span.span_id)
if span.context.sampling_priority
req.add_field(
Datadog::Ext::DistributedTracing::HTTP_HEADER_SAMPLING_PRIORITY,
span.context.sampling_priority
)
end
Datadog::HTTPPropagator.inject!(span.context, req)
end
rescue StandardError => e
Datadog::Tracer.log.error("error preparing span for http request: #{e}")
Expand Down
47 changes: 46 additions & 1 deletion spec/ddtrace/contrib/http/request_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -250,7 +250,52 @@ def expect_request_without_distributed_headers
if Gem::Version.new(RUBY_VERSION) < Gem::Version.new('2.3.0')
expect(WebMock).to(have_requested(:get, "#{uri}#{path}").with { |req|
distributed_tracing_headers.all? do |(header, value)|
req.headers[header.split('-').map(&:capitalize).join('-')] == value
req.headers[header.split('-').map(&:capitalize).join('-')] == value.to_s
end
})
else
expect(WebMock).to have_requested(:get, "#{uri}#{path}").with(headers: distributed_tracing_headers)
end
end
end

# This can happen if another http client uses net/http (e.g. restclient)
# The goal here is to ensure we do not add multiple values for a given header
context 'with existing distributed tracing headers' do
before(:each) do
tracer.configure(enabled: true)
tracer.trace('foo.bar') do |span|
span.context.sampling_priority = sampling_priority

req = Net::HTTP::Get.new(path)
req[Datadog::Ext::DistributedTracing::HTTP_HEADER_PARENT_ID] = 100
req[Datadog::Ext::DistributedTracing::HTTP_HEADER_TRACE_ID] = 100
req[Datadog::Ext::DistributedTracing::HTTP_HEADER_SAMPLING_PRIORITY] = 0

Net::HTTP.start(host, port) do |http|
http.request(req)
end
end
end

let(:sampling_priority) { 10 }
let(:distributed_tracing_headers) do
{
Datadog::Ext::DistributedTracing::HTTP_HEADER_PARENT_ID => span.span_id,
Datadog::Ext::DistributedTracing::HTTP_HEADER_TRACE_ID => span.trace_id,
Datadog::Ext::DistributedTracing::HTTP_HEADER_SAMPLING_PRIORITY => sampling_priority
}
end

let(:span) { spans.last }

it 'adds distributed tracing headers' do
# The block syntax only works with Ruby < 2.3 and the hash syntax
# only works with Ruby >= 2.3, so we need to support both.
if Gem::Version.new(RUBY_VERSION) < Gem::Version.new('2.3.0')
expect(WebMock).to(have_requested(:get, "#{uri}#{path}").with { |req|
distributed_tracing_headers.all? do |(header, value)|
req.headers[header.split('-').map(&:capitalize).join('-')] == value.to_s
end
})
else
Expand Down

0 comments on commit 1a9ff12

Please sign in to comment.