diff --git a/src/jaegertracing/Config.h b/src/jaegertracing/Config.h index 1c8a997..90696d1 100644 --- a/src/jaegertracing/Config.h +++ b/src/jaegertracing/Config.h @@ -68,6 +68,13 @@ class Config { const auto baggageRestrictionsNode = configYAML["baggage_restrictions"]; const auto baggageRestrictions = baggage::RestrictionsConfig::parse(baggageRestrictionsNode); + + std::vector tags; + const auto node = configYAML["tags"]; + for(YAML::const_iterator it = node.begin(); it != node.end(); ++it) { + tags.emplace_back(it->first.as(), it->second.as()); + } + return Config(disabled, traceId128Bit, sampler, @@ -75,7 +82,7 @@ class Config { headers, baggageRestrictions, serviceName, - std::vector(), + tags, propagationFormat); } diff --git a/src/jaegertracing/ConfigTest.cpp b/src/jaegertracing/ConfigTest.cpp index 15e91d2..f0e3326 100644 --- a/src/jaegertracing/ConfigTest.cpp +++ b/src/jaegertracing/ConfigTest.cpp @@ -107,6 +107,21 @@ propagation_format: w3c } } +TEST(Config, testTags) +{ + { + constexpr auto kConfigYAML = R"cfg( +tags: + foo: bar +)cfg"; + const auto config = Config::parse(YAML::Load(kConfigYAML)); + + std::vector expectedTags; + expectedTags.emplace_back("foo", std::string("bar")); + ASSERT_EQ(expectedTags, config.tags()); + } +} + #endif // JAEGERTRACING_WITH_YAML_CPP TEST(Config, testFromEnv)