diff options
| author | vvminashkin <[email protected]> | 2026-03-02 12:13:39 +0300 |
|---|---|---|
| committer | vvminashkin <[email protected]> | 2026-03-02 13:04:29 +0300 |
| commit | b065a51848d90f8131a4861ebd6ec4f4e79f548f (patch) | |
| tree | 908bccce181c50611bf891daded56c1fbbd35b39 /library/cpp/monlib/encode/prometheus/prometheus_decoder_ut.cpp | |
| parent | 49c8ec452cfb6220fc817bbb4d4667e440060ce0 (diff) | |
[cpp/monlib] add ability to mangle name in prometheus decoder
commit_hash:ef6584bf0941f50d0833dacd3b5d14cfc1cd30a8
Diffstat (limited to 'library/cpp/monlib/encode/prometheus/prometheus_decoder_ut.cpp')
| -rw-r--r-- | library/cpp/monlib/encode/prometheus/prometheus_decoder_ut.cpp | 57 |
1 files changed, 57 insertions, 0 deletions
diff --git a/library/cpp/monlib/encode/prometheus/prometheus_decoder_ut.cpp b/library/cpp/monlib/encode/prometheus/prometheus_decoder_ut.cpp index 4dbb4b574bb..f6b3eb01667 100644 --- a/library/cpp/monlib/encode/prometheus/prometheus_decoder_ut.cpp +++ b/library/cpp/monlib/encode/prometheus/prometheus_decoder_ut.cpp @@ -105,6 +105,63 @@ Y_UNIT_TEST_SUITE(TPrometheusDecoderTest) { } } + Y_UNIT_TEST(NameAlreadyPresent) { + constexpr auto inputMetrics = + "# A normal comment.\n" + "#\n" + "# TYPE name counter\n" + "name{sensor=\"some_name\",labelname=\"val1\",basename=\"basevalue\"} NaN\n" + "name{labelname=\"val2\",basename=\"basevalue\"} Nan\n" + "name {labelname=\"val3\",basename=\"basevalue\"} 2.3 1234567890\n" + "# HELP name two-line\\n doc str\\\\ing\n"; + + try { + auto samples = Decode(inputMetrics); + } catch(...) { + return; + } + UNIT_ASSERT(false); + } + + Y_UNIT_TEST(NameAlreadyPresentButMangled) { + constexpr auto inputMetrics = + "# A normal comment.\n" + "#\n" + "# TYPE name counter\n" + "name{sensor=\"some_name\",labelname=\"val1\",basename=\"basevalue\"} NaN\n" + "name{labelname=\"val2\",basename=\"basevalue\"} Nan\n" + "name {labelname=\"val3\",basename=\"basevalue\"} 2.3 1234567890\n" + "# HELP name two-line\\n doc str\\\\ing\n"; + + try { + auto samples = Decode(inputMetrics, TPrometheusDecodeSettings{.NameMangler = [](auto s) -> TString { + return TStringBuilder{}<<"mm_" << s; + }}); + } catch(...) { + UNIT_ASSERT(false); + } + } + + Y_UNIT_TEST(MangledNameClash) { + constexpr auto inputMetrics = + "# A normal comment.\n" + "#\n" + "# TYPE name counter\n" + "name{mm_sensor=\"other\",sensor=\"some_name\",labelname=\"val1\",basename=\"basevalue\"} NaN\n" + "name{labelname=\"val2\",basename=\"basevalue\"} Nan\n" + "name {labelname=\"val3\",basename=\"basevalue\"} 2.3 1234567890\n" + "# HELP name two-line\\n doc str\\\\ing\n"; + + try { + auto samples = Decode(inputMetrics, TPrometheusDecodeSettings{.NameMangler = [](auto s) -> TString { + return TStringBuilder{}<<"mm_" << s; + }}); + } catch(...) { + return; + } + UNIT_ASSERT(false); + } + Y_UNIT_TEST(Counter) { constexpr auto inputMetrics = "# A normal comment.\n" |
