From c77065e2b55a81db0673e9da946e1b6ccf488951 Mon Sep 17 00:00:00 2001 From: Pranav Sharma Date: Mon, 18 Nov 2024 15:30:43 +0000 Subject: [PATCH] Add unit test for custom configurator --- sdk/test/trace/tracer_test.cc | 43 +++++++++++++++++++++++++++++++++-- 1 file changed, 41 insertions(+), 2 deletions(-) diff --git a/sdk/test/trace/tracer_test.cc b/sdk/test/trace/tracer_test.cc index feffeffbdf..118f18ba83 100644 --- a/sdk/test/trace/tracer_test.cc +++ b/sdk/test/trace/tracer_test.cc @@ -150,7 +150,8 @@ std::shared_ptr initTracer( Sampler *sampler, IdGenerator *id_generator = new RandomIdGenerator, const ScopeConfigurator &tracer_configurator = - TracerConfig::DefaultConfigurator()) + TracerConfig::DefaultConfigurator(), + std::unique_ptr scope = InstrumentationScope::Create("")) { auto processor = std::unique_ptr(new SimpleSpanProcessor(std::move(exporter))); std::vector> processors; @@ -160,7 +161,7 @@ std::shared_ptr initTracer( std::move(processors), resource, std::unique_ptr(sampler), std::unique_ptr(id_generator), std::make_unique>(tracer_configurator)); - return std::shared_ptr(new Tracer(context)); + return std::shared_ptr(new Tracer(context, std::move(scope))); } } // namespace @@ -536,6 +537,44 @@ TEST(Tracer, StartSpanWithEnabledConfig) #endif } +TEST(Tracer, StartSpanWithCustomConfig) +{ +#ifdef OPENTELEMETRY_RTTI_ENABLED + ScopeConfigurator custom_configurator = [](const InstrumentationScope &scope) { + if (scope.GetName() == "" || scope.GetName() == "foo_library") + { + return TracerConfig::Disabled(); + } + return TracerConfig::Enabled(); + }; + + const auto tracer_default_scope = + initTracer(std::unique_ptr{new InMemorySpanExporter()}, new AlwaysOnSampler(), + new RandomIdGenerator(), custom_configurator); + const auto span_default_scope = tracer_default_scope->StartSpan("span 1"); + const auto &span_default_scope_ref = *span_default_scope.get(); + EXPECT_EQ(typeid(span_default_scope_ref), typeid(trace_api::NoopSpan)); + + auto foo_scope = InstrumentationScope::Create("foo_library"); + const auto tracer_foo_scope = + initTracer(std::unique_ptr{new InMemorySpanExporter()}, new AlwaysOnSampler(), + new RandomIdGenerator(), custom_configurator, std::move(foo_scope)); + const auto span_foo_scope = tracer_foo_scope->StartSpan("span 1"); + auto &span_foo_scope_ref = *span_foo_scope.get(); + EXPECT_EQ(typeid(span_foo_scope_ref), typeid(trace_api::NoopSpan)); + + auto bar_scope = InstrumentationScope::Create("bar_library"); + auto tracer_bar_scope = + initTracer(std::unique_ptr{new InMemorySpanExporter()}, new AlwaysOnSampler(), + new RandomIdGenerator(), custom_configurator, std::move(bar_scope)); + auto span_bar_scope = tracer_bar_scope->StartSpan("span 1"); + auto &span_bar_scope_ref = *span_bar_scope.get(); + EXPECT_EQ(typeid(span_bar_scope_ref), typeid(opentelemetry::sdk::trace::Span)); +#else + GTEST_SKIP() << "cannot use 'typeid' with '-fno-rtti'"; +#endif +} + TEST(Tracer, SpanSetLinks) { InMemorySpanExporter *exporter = new InMemorySpanExporter();