parent_sampler_test.cc 4.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. // Copyright The OpenTelemetry Authors
  2. // SPDX-License-Identifier: Apache-2.0
  3. #include <gtest/gtest.h>
  4. #include <cstdint>
  5. #include <map>
  6. #include <string>
  7. #include <utility>
  8. #include <vector>
  9. #include "opentelemetry/common/key_value_iterable_view.h"
  10. #include "opentelemetry/nostd/shared_ptr.h"
  11. #include "opentelemetry/nostd/span.h"
  12. #include "opentelemetry/sdk/trace/sampler.h"
  13. #include "opentelemetry/sdk/trace/samplers/always_off.h"
  14. #include "opentelemetry/sdk/trace/samplers/always_on.h"
  15. #include "opentelemetry/sdk/trace/samplers/parent.h"
  16. #include "opentelemetry/trace/span_context.h"
  17. #include "opentelemetry/trace/span_context_kv_iterable_view.h"
  18. #include "opentelemetry/trace/span_id.h"
  19. #include "opentelemetry/trace/span_metadata.h"
  20. #include "opentelemetry/trace/trace_flags.h"
  21. #include "opentelemetry/trace/trace_id.h"
  22. #include "opentelemetry/trace/trace_state.h"
  23. using opentelemetry::sdk::trace::AlwaysOffSampler;
  24. using opentelemetry::sdk::trace::AlwaysOnSampler;
  25. using opentelemetry::sdk::trace::Decision;
  26. using opentelemetry::sdk::trace::ParentBasedSampler;
  27. namespace trace_api = opentelemetry::trace;
  28. TEST(ParentBasedSampler, ShouldSample)
  29. {
  30. ParentBasedSampler sampler_off(std::make_shared<AlwaysOffSampler>());
  31. ParentBasedSampler sampler_on(std::make_shared<AlwaysOnSampler>());
  32. // Set up parameters
  33. uint8_t trace_id_buffer[trace_api::TraceId::kSize] = {1};
  34. trace_api::TraceId trace_id{trace_id_buffer};
  35. uint8_t span_id_buffer[trace_api::SpanId::kSize] = {1};
  36. trace_api::SpanId span_id{span_id_buffer};
  37. trace_api::SpanKind span_kind = trace_api::SpanKind::kInternal;
  38. using M = std::map<std::string, int>;
  39. M m1 = {{}};
  40. using L = std::vector<std::pair<trace_api::SpanContext, std::map<std::string, std::string>>>;
  41. L l1 = {{trace_api::SpanContext(false, false), {}}, {trace_api::SpanContext(false, false), {}}};
  42. opentelemetry::common::KeyValueIterableView<M> view{m1};
  43. trace_api::SpanContextKeyValueIterableView<L> links{l1};
  44. auto trace_state = trace_api::TraceState::FromHeader("congo=t61rcWkgMzE");
  45. trace_api::SpanContext parent_context_sampled(trace_id, span_id, trace_api::TraceFlags{1}, false,
  46. trace_state);
  47. trace_api::SpanContext parent_context_nonsampled(trace_id, span_id, trace_api::TraceFlags{0},
  48. false, trace_state);
  49. // Case 1: Parent doesn't exist. Return result of delegateSampler()
  50. auto sampling_result = sampler_off.ShouldSample(trace_api::SpanContext::GetInvalid(), trace_id,
  51. "", span_kind, view, links);
  52. auto sampling_result2 = sampler_on.ShouldSample(trace_api::SpanContext::GetInvalid(), trace_id,
  53. "", span_kind, view, links);
  54. ASSERT_EQ(Decision::DROP, sampling_result.decision);
  55. ASSERT_EQ(Decision::RECORD_AND_SAMPLE, sampling_result2.decision);
  56. ASSERT_EQ("", sampling_result.trace_state->ToHeader());
  57. ASSERT_EQ("", sampling_result2.trace_state->ToHeader());
  58. // Case 2: Parent exists and SampledFlag is true
  59. auto sampling_result3 =
  60. sampler_off.ShouldSample(parent_context_sampled, trace_id, "", span_kind, view, links);
  61. ASSERT_EQ(Decision::RECORD_AND_SAMPLE, sampling_result3.decision);
  62. ASSERT_EQ("congo=t61rcWkgMzE", sampling_result3.trace_state->ToHeader());
  63. // Case 3: Parent exists and SampledFlag is false
  64. auto sampling_result4 =
  65. sampler_on.ShouldSample(parent_context_nonsampled, trace_id, "", span_kind, view, links);
  66. ASSERT_EQ(Decision::DROP, sampling_result4.decision);
  67. ASSERT_EQ("congo=t61rcWkgMzE", sampling_result4.trace_state->ToHeader());
  68. }
  69. TEST(ParentBasedSampler, GetDescription)
  70. {
  71. ParentBasedSampler sampler(std::make_shared<AlwaysOffSampler>());
  72. ASSERT_EQ("ParentBased{AlwaysOffSampler}", sampler.GetDescription());
  73. ParentBasedSampler sampler2(std::make_shared<AlwaysOnSampler>());
  74. ASSERT_EQ("ParentBased{AlwaysOnSampler}", sampler2.GetDescription());
  75. }