From 3a139f21a297a95c1165241112beb04a4807dd70 Mon Sep 17 00:00:00 2001 From: Lalit Date: Tue, 13 Aug 2024 23:36:02 -0700 Subject: [PATCH 1/5] support empty buckets --- .../aggregation/histogram_aggregation.cc | 4 +- sdk/test/metrics/histogram_test.cc | 120 ++++++++++++++++++ 2 files changed, 122 insertions(+), 2 deletions(-) diff --git a/sdk/src/metrics/aggregation/histogram_aggregation.cc b/sdk/src/metrics/aggregation/histogram_aggregation.cc index da725cf09c..d6b4c90a0b 100644 --- a/sdk/src/metrics/aggregation/histogram_aggregation.cc +++ b/sdk/src/metrics/aggregation/histogram_aggregation.cc @@ -28,7 +28,7 @@ namespace metrics LongHistogramAggregation::LongHistogramAggregation(const AggregationConfig *aggregation_config) { auto ac = static_cast(aggregation_config); - if (ac && ac->boundaries_.size()) + if (ac) { point_data_.boundaries_ = ac->boundaries_; } @@ -109,7 +109,7 @@ PointType LongHistogramAggregation::ToPoint() const noexcept DoubleHistogramAggregation::DoubleHistogramAggregation(const AggregationConfig *aggregation_config) { auto ac = static_cast(aggregation_config); - if (ac && ac->boundaries_.size()) + if (ac) { point_data_.boundaries_ = ac->boundaries_; } diff --git a/sdk/test/metrics/histogram_test.cc b/sdk/test/metrics/histogram_test.cc index 4daceb685b..88029f5c5a 100644 --- a/sdk/test/metrics/histogram_test.cc +++ b/sdk/test/metrics/histogram_test.cc @@ -134,6 +134,66 @@ TEST(Histogram, DoubleCustomBuckets) ASSERT_EQ(std::vector({10, 20, 30, 40}), actual.boundaries_); ASSERT_EQ(std::vector({2, 2, 2, 2, 2}), actual.counts_); } + +TEST(Histogram, DoubleEmptyBuckets) +{ + MeterProvider mp; + auto m = mp.GetMeter("meter1", "version1", "schema1"); + std::string instrument_unit = "ms"; + std::string instrument_name = "historgram1"; + std::string instrument_desc = "histogram metrics"; + + std::unique_ptr exporter(new MockMetricExporter()); + std::shared_ptr reader{new MockMetricReader(std::move(exporter))}; + mp.AddMetricReader(reader); + + std::shared_ptr config(new HistogramAggregationConfig()); + config->boundaries_ = {}; + std::unique_ptr view{ + new View("view1", "view1_description", instrument_unit, AggregationType::kHistogram, config)}; + std::unique_ptr instrument_selector{ + new InstrumentSelector(InstrumentType::kHistogram, instrument_name, instrument_unit)}; + std::unique_ptr meter_selector{new MeterSelector("meter1", "version1", "schema1")}; + mp.AddView(std::move(instrument_selector), std::move(meter_selector), std::move(view)); + + auto h = m->CreateDoubleHistogram(instrument_name, instrument_desc, instrument_unit); + + h->Record(5, {}); + h->Record(10, {}); + h->Record(15, {}); + h->Record(20, {}); + h->Record(25, {}); + h->Record(30, {}); + h->Record(35, {}); + h->Record(40, {}); + h->Record(45, {}); + h->Record(50, {}); + + std::vector actuals; + reader->Collect([&](ResourceMetrics &rm) { + for (const ScopeMetrics &smd : rm.scope_metric_data_) + { + for (const MetricData &md : smd.metric_data_) + { + for (const PointDataAttributes &dp : md.point_data_attr_) + { + actuals.push_back(opentelemetry::nostd::get(dp.point_data)); + } + } + } + return true; + }); + + ASSERT_EQ(1, actuals.size()); + + const auto &actual = actuals.at(0); + ASSERT_EQ(275.0, opentelemetry::nostd::get(actual.sum_)); + ASSERT_EQ(10, actual.count_); + ASSERT_EQ(5.0, opentelemetry::nostd::get(actual.min_)); + ASSERT_EQ(50.0, opentelemetry::nostd::get(actual.max_)); + ASSERT_EQ(std::vector({}), actual.boundaries_); + ASSERT_EQ(std::vector({10}), actual.counts_); +} #endif TEST(Histogram, UInt64) @@ -249,4 +309,64 @@ TEST(Histogram, UInt64CustomBuckets) ASSERT_EQ(std::vector({10, 20, 30, 40}), actual.boundaries_); ASSERT_EQ(std::vector({2, 2, 2, 2, 2}), actual.counts_); } + +TEST(Histogram, UInt64EmptyBuckets) +{ + MeterProvider mp; + auto m = mp.GetMeter("meter1", "version1", "schema1"); + std::string instrument_name = "historgram1"; + std::string instrument_desc = "histogram metrics"; + std::string instrument_unit = "ms"; + + std::unique_ptr exporter(new MockMetricExporter()); + std::shared_ptr reader{new MockMetricReader(std::move(exporter))}; + mp.AddMetricReader(reader); + + std::shared_ptr config(new HistogramAggregationConfig()); + config->boundaries_ = {}; + std::unique_ptr view{ + new View("view1", "view1_description", "ms", AggregationType::kHistogram, config)}; + std::unique_ptr instrument_selector{ + new InstrumentSelector(InstrumentType::kHistogram, instrument_name, instrument_unit)}; + std::unique_ptr meter_selector{new MeterSelector("meter1", "version1", "schema1")}; + mp.AddView(std::move(instrument_selector), std::move(meter_selector), std::move(view)); + + auto h = m->CreateUInt64Histogram(instrument_name, instrument_desc, instrument_unit); + + h->Record(5, {}); + h->Record(10, {}); + h->Record(15, {}); + h->Record(20, {}); + h->Record(25, {}); + h->Record(30, {}); + h->Record(35, {}); + h->Record(40, {}); + h->Record(45, {}); + h->Record(50, {}); + + std::vector actuals; + reader->Collect([&](ResourceMetrics &rm) { + for (const ScopeMetrics &smd : rm.scope_metric_data_) + { + for (const MetricData &md : smd.metric_data_) + { + for (const PointDataAttributes &dp : md.point_data_attr_) + { + actuals.push_back(opentelemetry::nostd::get(dp.point_data)); + } + } + } + return true; + }); + + ASSERT_EQ(1, actuals.size()); + + const auto &actual = actuals.at(0); + ASSERT_EQ(275, opentelemetry::nostd::get(actual.sum_)); + ASSERT_EQ(10, actual.count_); + ASSERT_EQ(5, opentelemetry::nostd::get(actual.min_)); + ASSERT_EQ(50, opentelemetry::nostd::get(actual.max_)); + ASSERT_EQ(std::vector({}), actual.boundaries_); + ASSERT_EQ(std::vector({10}), actual.counts_); +} #endif From cf9e9b9e6c400d22c35f98f93e95447c1a56b435 Mon Sep 17 00:00:00 2001 From: Lalit Kumar Bhasin Date: Wed, 14 Aug 2024 09:43:04 -0700 Subject: [PATCH 2/5] Update histogram_test.cc --- sdk/test/metrics/histogram_test.cc | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/sdk/test/metrics/histogram_test.cc b/sdk/test/metrics/histogram_test.cc index 88029f5c5a..5246345918 100644 --- a/sdk/test/metrics/histogram_test.cc +++ b/sdk/test/metrics/histogram_test.cc @@ -158,7 +158,7 @@ TEST(Histogram, DoubleEmptyBuckets) auto h = m->CreateDoubleHistogram(instrument_name, instrument_desc, instrument_unit); - h->Record(5, {}); + h->Record(-5, {}); h->Record(10, {}); h->Record(15, {}); h->Record(20, {}); @@ -187,9 +187,9 @@ TEST(Histogram, DoubleEmptyBuckets) ASSERT_EQ(1, actuals.size()); const auto &actual = actuals.at(0); - ASSERT_EQ(275.0, opentelemetry::nostd::get(actual.sum_)); + ASSERT_EQ(265.0, opentelemetry::nostd::get(actual.sum_)); ASSERT_EQ(10, actual.count_); - ASSERT_EQ(5.0, opentelemetry::nostd::get(actual.min_)); + ASSERT_EQ(-5.0, opentelemetry::nostd::get(actual.min_)); ASSERT_EQ(50.0, opentelemetry::nostd::get(actual.max_)); ASSERT_EQ(std::vector({}), actual.boundaries_); ASSERT_EQ(std::vector({10}), actual.counts_); From 3e098556988506b7b54308283636bef36f11f1b7 Mon Sep 17 00:00:00 2001 From: Lalit Kumar Bhasin Date: Wed, 14 Aug 2024 09:48:43 -0700 Subject: [PATCH 3/5] Update histogram_test.cc --- sdk/test/metrics/histogram_test.cc | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/sdk/test/metrics/histogram_test.cc b/sdk/test/metrics/histogram_test.cc index 5246345918..011b6a188e 100644 --- a/sdk/test/metrics/histogram_test.cc +++ b/sdk/test/metrics/histogram_test.cc @@ -187,7 +187,7 @@ TEST(Histogram, DoubleEmptyBuckets) ASSERT_EQ(1, actuals.size()); const auto &actual = actuals.at(0); - ASSERT_EQ(265.0, opentelemetry::nostd::get(actual.sum_)); + ASSERT_EQ(270.0, opentelemetry::nostd::get(actual.sum_)); ASSERT_EQ(10, actual.count_); ASSERT_EQ(-5.0, opentelemetry::nostd::get(actual.min_)); ASSERT_EQ(50.0, opentelemetry::nostd::get(actual.max_)); From 6ba1198471debaccdb9dbffac8f174188e62dabc Mon Sep 17 00:00:00 2001 From: Lalit Kumar Bhasin Date: Wed, 14 Aug 2024 10:04:28 -0700 Subject: [PATCH 4/5] test for negative values --- sdk/test/metrics/histogram_test.cc | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/sdk/test/metrics/histogram_test.cc b/sdk/test/metrics/histogram_test.cc index 011b6a188e..14d37febbd 100644 --- a/sdk/test/metrics/histogram_test.cc +++ b/sdk/test/metrics/histogram_test.cc @@ -188,8 +188,8 @@ TEST(Histogram, DoubleEmptyBuckets) const auto &actual = actuals.at(0); ASSERT_EQ(270.0, opentelemetry::nostd::get(actual.sum_)); - ASSERT_EQ(10, actual.count_); - ASSERT_EQ(-5.0, opentelemetry::nostd::get(actual.min_)); + ASSERT_EQ(9, actual.count_); + ASSERT_EQ(10.0, opentelemetry::nostd::get(actual.min_)); ASSERT_EQ(50.0, opentelemetry::nostd::get(actual.max_)); ASSERT_EQ(std::vector({}), actual.boundaries_); ASSERT_EQ(std::vector({10}), actual.counts_); From a36fbbcec3c30e077f276cca43ef31c9bb393e05 Mon Sep 17 00:00:00 2001 From: Lalit Kumar Bhasin Date: Wed, 14 Aug 2024 10:16:31 -0700 Subject: [PATCH 5/5] fix count --- sdk/test/metrics/histogram_test.cc | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/sdk/test/metrics/histogram_test.cc b/sdk/test/metrics/histogram_test.cc index 14d37febbd..57f7790ba1 100644 --- a/sdk/test/metrics/histogram_test.cc +++ b/sdk/test/metrics/histogram_test.cc @@ -192,7 +192,7 @@ TEST(Histogram, DoubleEmptyBuckets) ASSERT_EQ(10.0, opentelemetry::nostd::get(actual.min_)); ASSERT_EQ(50.0, opentelemetry::nostd::get(actual.max_)); ASSERT_EQ(std::vector({}), actual.boundaries_); - ASSERT_EQ(std::vector({10}), actual.counts_); + ASSERT_EQ(std::vector({9}), actual.counts_); } #endif