jaeger_propagation_test.cc 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207
  1. // Copyright The OpenTelemetry Authors
  2. // SPDX-License-Identifier: Apache-2.0
  3. #include <gtest/gtest.h>
  4. #include <stdint.h>
  5. #include <algorithm>
  6. #include <map>
  7. #include <string>
  8. #include <utility>
  9. #include <vector>
  10. #include "util.h"
  11. #include "opentelemetry/context/context.h"
  12. #include "opentelemetry/context/propagation/text_map_propagator.h"
  13. #include "opentelemetry/context/runtime_context.h"
  14. #include "opentelemetry/nostd/function_ref.h"
  15. #include "opentelemetry/nostd/shared_ptr.h"
  16. #include "opentelemetry/nostd/span.h"
  17. #include "opentelemetry/nostd/string_view.h"
  18. #include "opentelemetry/nostd/variant.h"
  19. #include "opentelemetry/trace/context.h"
  20. #include "opentelemetry/trace/default_span.h"
  21. #include "opentelemetry/trace/propagation/jaeger.h"
  22. #include "opentelemetry/trace/scope.h"
  23. #include "opentelemetry/trace/span.h"
  24. #include "opentelemetry/trace/span_context.h"
  25. #include "opentelemetry/trace/span_id.h"
  26. #include "opentelemetry/trace/span_metadata.h"
  27. #include "opentelemetry/trace/trace_flags.h"
  28. #include "opentelemetry/trace/trace_id.h"
  29. using namespace opentelemetry;
  30. class TextMapCarrierTest : public context::propagation::TextMapCarrier
  31. {
  32. public:
  33. nostd::string_view Get(nostd::string_view key) const noexcept override
  34. {
  35. auto it = headers_.find(std::string(key));
  36. if (it != headers_.end())
  37. {
  38. return nostd::string_view(it->second);
  39. }
  40. return "";
  41. }
  42. void Set(nostd::string_view key, nostd::string_view value) noexcept override
  43. {
  44. headers_[std::string(key)] = std::string(value);
  45. }
  46. std::map<std::string, std::string> headers_;
  47. };
  48. using Propagator = trace::propagation::JaegerPropagator;
  49. static Propagator format = Propagator();
  50. TEST(JaegerPropagatorTest, ExtractValidSpans)
  51. {
  52. struct TestTrace
  53. {
  54. std::string trace_state;
  55. std::string expected_trace_id;
  56. std::string expected_span_id;
  57. bool sampled;
  58. };
  59. std::vector<TestTrace> traces = {
  60. {
  61. "4bf92f3577b34da6a3ce929d0e0e4736:0102030405060708:0:00",
  62. "4bf92f3577b34da6a3ce929d0e0e4736",
  63. "0102030405060708",
  64. false,
  65. },
  66. {
  67. "4bf92f3577b34da6a3ce929d0e0e4736:0102030405060708:0:ff",
  68. "4bf92f3577b34da6a3ce929d0e0e4736",
  69. "0102030405060708",
  70. true,
  71. },
  72. {
  73. "4bf92f3577b34da6a3ce929d0e0e4736:0102030405060708:0:f",
  74. "4bf92f3577b34da6a3ce929d0e0e4736",
  75. "0102030405060708",
  76. true,
  77. },
  78. {
  79. "a3ce929d0e0e4736:0102030405060708:0:00",
  80. "0000000000000000a3ce929d0e0e4736",
  81. "0102030405060708",
  82. false,
  83. },
  84. {
  85. "A3CE929D0E0E4736:ABCDEFABCDEF1234:0:01",
  86. "0000000000000000a3ce929d0e0e4736",
  87. "abcdefabcdef1234",
  88. true,
  89. },
  90. {
  91. "ff:ABCDEFABCDEF1234:0:0",
  92. "000000000000000000000000000000ff",
  93. "abcdefabcdef1234",
  94. false,
  95. },
  96. {
  97. "4bf92f3577b34da6a3ce929d0e0e4736:0102030405060708:0102030405060708:00",
  98. "4bf92f3577b34da6a3ce929d0e0e4736",
  99. "0102030405060708",
  100. false,
  101. },
  102. };
  103. for (TestTrace &test_trace : traces)
  104. {
  105. TextMapCarrierTest carrier;
  106. carrier.headers_ = {{"uber-trace-id", test_trace.trace_state}};
  107. context::Context ctx1 = context::Context{};
  108. context::Context ctx2 = format.Extract(carrier, ctx1);
  109. auto span = trace::GetSpan(ctx2)->GetContext();
  110. EXPECT_TRUE(span.IsValid());
  111. EXPECT_EQ(Hex(span.trace_id()), test_trace.expected_trace_id);
  112. EXPECT_EQ(Hex(span.span_id()), test_trace.expected_span_id);
  113. EXPECT_EQ(span.IsSampled(), test_trace.sampled);
  114. EXPECT_EQ(span.IsRemote(), true);
  115. }
  116. }
  117. TEST(JaegerPropagatorTest, ExctractInvalidSpans)
  118. {
  119. TextMapCarrierTest carrier;
  120. std::vector<std::string> traces = {
  121. "4bf92f3577b34da6a3ce929d0e0e47344:0102030405060708:0:00", // too long trace id
  122. "4bf92f3577b34da6a3ce929d0e0e4734:01020304050607089:0:00", // too long span id
  123. "4bf92f3577b34da6x3ce929d0y0e4734:01020304050607089:0:00", // invalid trace id character
  124. "4bf92f3577b34da6a3ce929d0e0e4734:01020304g50607089:0:00", // invalid span id character
  125. "4bf92f3577b34da6a3ce929d0e0e4734::0:00",
  126. "",
  127. "::::",
  128. "0:0:0:0",
  129. ":abcdef12:0:0",
  130. };
  131. for (auto &trace : traces)
  132. {
  133. carrier.headers_ = {{"uber-trace-id", trace}};
  134. context::Context ctx1 = context::Context{};
  135. context::Context ctx2 = format.Extract(carrier, ctx1);
  136. auto span = trace::GetSpan(ctx2)->GetContext();
  137. EXPECT_FALSE(span.IsValid());
  138. }
  139. }
  140. TEST(JaegerPropagatorTest, DoNotOverwriteContextWithInvalidSpan)
  141. {
  142. TextMapCarrierTest carrier;
  143. constexpr uint8_t buf_span[] = {1, 2, 3, 4, 5, 6, 7, 8};
  144. constexpr uint8_t buf_trace[] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16};
  145. trace::SpanContext span_context{trace::TraceId{buf_trace}, trace::SpanId{buf_span},
  146. trace::TraceFlags{true}, false};
  147. nostd::shared_ptr<trace::Span> sp{new trace::DefaultSpan{span_context}};
  148. // Make sure this invalid span does not overwrite the active span context
  149. carrier.headers_ = {{"uber-trace-id", "foo:bar:0:00"}};
  150. context::Context ctx1{trace::kSpanKey, sp};
  151. context::Context ctx2 = format.Extract(carrier, ctx1);
  152. auto ctx2_span = ctx2.GetValue(trace::kSpanKey);
  153. auto span = nostd::get<nostd::shared_ptr<trace::Span>>(ctx2_span);
  154. EXPECT_EQ(Hex(span->GetContext().trace_id()), "0102030405060708090a0b0c0d0e0f10");
  155. }
  156. TEST(JaegerPropagatorTest, InjectsContext)
  157. {
  158. TextMapCarrierTest carrier;
  159. constexpr uint8_t buf_span[] = {1, 2, 3, 4, 5, 6, 7, 8};
  160. constexpr uint8_t buf_trace[] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16};
  161. trace::SpanContext span_context{trace::TraceId{buf_trace}, trace::SpanId{buf_span},
  162. trace::TraceFlags{true}, false};
  163. nostd::shared_ptr<trace::Span> sp{new trace::DefaultSpan{span_context}};
  164. trace::Scope scoped_span{sp};
  165. format.Inject(carrier, context::RuntimeContext::GetCurrent());
  166. EXPECT_EQ(carrier.headers_["uber-trace-id"],
  167. "0102030405060708090a0b0c0d0e0f10:0102030405060708:0:01");
  168. std::vector<std::string> fields;
  169. format.Fields([&fields](nostd::string_view field) {
  170. fields.push_back(field.data());
  171. return true;
  172. });
  173. EXPECT_EQ(fields.size(), 1);
  174. EXPECT_EQ(fields[0], opentelemetry::trace::propagation::kJaegerTraceHeader);
  175. }
  176. TEST(JaegerPropagatorTest, DoNotInjectInvalidContext)
  177. {
  178. TextMapCarrierTest carrier;
  179. context::Context ctx{
  180. trace::kSpanKey,
  181. nostd::shared_ptr<trace::Span>(new trace::DefaultSpan(trace::SpanContext::GetInvalid()))};
  182. format.Inject(carrier, ctx);
  183. EXPECT_TRUE(carrier.headers_.count("uber-trace-id") == 0);
  184. }