summaryrefslogtreecommitdiffstats
path: root/src/jaegertracing/opentelemetry-cpp/sdk/test/metrics/async_metric_storage_test.cc
diff options
context:
space:
mode:
Diffstat (limited to 'src/jaegertracing/opentelemetry-cpp/sdk/test/metrics/async_metric_storage_test.cc')
-rw-r--r--src/jaegertracing/opentelemetry-cpp/sdk/test/metrics/async_metric_storage_test.cc132
1 files changed, 132 insertions, 0 deletions
diff --git a/src/jaegertracing/opentelemetry-cpp/sdk/test/metrics/async_metric_storage_test.cc b/src/jaegertracing/opentelemetry-cpp/sdk/test/metrics/async_metric_storage_test.cc
new file mode 100644
index 000000000..2be5332a8
--- /dev/null
+++ b/src/jaegertracing/opentelemetry-cpp/sdk/test/metrics/async_metric_storage_test.cc
@@ -0,0 +1,132 @@
+// Copyright The OpenTelemetry Authors
+// SPDX-License-Identifier: Apache-2.0
+
+#ifndef ENABLE_METRICS_PREVIEW
+# include "opentelemetry/sdk/metrics/state/async_metric_storage.h"
+# include "opentelemetry/common/key_value_iterable_view.h"
+# include "opentelemetry/sdk/metrics/instruments.h"
+# include "opentelemetry/sdk/metrics/meter_context.h"
+# include "opentelemetry/sdk/metrics/metric_exporter.h"
+# include "opentelemetry/sdk/metrics/metric_reader.h"
+# include "opentelemetry/sdk/metrics/observer_result.h"
+# include "opentelemetry/sdk/metrics/state/metric_collector.h"
+
+# include <gtest/gtest.h>
+# include <vector>
+
+using namespace opentelemetry::sdk::metrics;
+using namespace opentelemetry::sdk::instrumentationlibrary;
+using namespace opentelemetry::sdk::resource;
+
+using namespace opentelemetry::sdk::metrics;
+using namespace opentelemetry::common;
+using M = std::map<std::string, std::string>;
+
+class MockCollectorHandle : public CollectorHandle
+{
+public:
+ MockCollectorHandle(AggregationTemporality temp) : temporality(temp) {}
+
+ AggregationTemporality GetAggregationTemporality() noexcept override { return temporality; }
+
+private:
+ AggregationTemporality temporality;
+};
+
+class WritableMetricStorageTestFixture : public ::testing::TestWithParam<AggregationTemporality>
+{};
+
+class MeasurementFetcher
+{
+public:
+ static void Fetcher(opentelemetry::metrics::ObserverResult<long> &observer_result,
+ void * /*state*/)
+ {
+ fetch_count++;
+ if (fetch_count == 1)
+ {
+ observer_result.Observe(20l, {{"RequestType", "GET"}});
+ observer_result.Observe(10l, {{"RequestType", "PUT"}});
+ number_of_get += 20l;
+ number_of_put += 10l;
+ }
+ else if (fetch_count == 2)
+ {
+ observer_result.Observe(40l, {{"RequestType", "GET"}});
+ observer_result.Observe(20l, {{"RequestType", "PUT"}});
+ number_of_get += 40l;
+ number_of_put += 20l;
+ }
+ }
+
+ static void init_values()
+ {
+ fetch_count = 0;
+ number_of_get = 0;
+ number_of_put = 0;
+ }
+
+ static size_t fetch_count;
+ static long number_of_get;
+ static long number_of_put;
+ static const size_t number_of_attributes = 2; // GET , PUT
+};
+
+size_t MeasurementFetcher::fetch_count;
+long MeasurementFetcher::number_of_get;
+long MeasurementFetcher::number_of_put;
+const size_t MeasurementFetcher::number_of_attributes;
+
+TEST_P(WritableMetricStorageTestFixture, TestAggregation)
+{
+ MeasurementFetcher::init_values();
+ AggregationTemporality temporality = GetParam();
+
+ InstrumentDescriptor instr_desc = {"name", "desc", "1unit", InstrumentType::kObservableCounter,
+ InstrumentValueType::kLong};
+
+ auto sdk_start_ts = std::chrono::system_clock::now();
+ // Some computation here
+ auto collection_ts = std::chrono::system_clock::now() + std::chrono::seconds(5);
+
+ std::shared_ptr<CollectorHandle> collector(new MockCollectorHandle(temporality));
+ std::vector<std::shared_ptr<CollectorHandle>> collectors;
+ collectors.push_back(collector);
+ size_t count_attributes = 0;
+ long value = 0;
+
+ MeasurementFetcher measurement_fetcher;
+ opentelemetry::sdk::metrics::AsyncMetricStorage<long> storage(instr_desc, AggregationType::kSum,
+ MeasurementFetcher::Fetcher,
+ new DefaultAttributesProcessor());
+
+ storage.Collect(collector.get(), collectors, sdk_start_ts, collection_ts,
+ [&](const MetricData data) {
+ for (auto data_attr : data.point_data_attr_)
+ {
+ auto data = opentelemetry::nostd::get<SumPointData>(data_attr.point_data);
+ if (opentelemetry::nostd::get<std::string>(
+ data_attr.attributes.find("RequestType")->second) == "GET")
+ {
+ EXPECT_EQ(opentelemetry::nostd::get<long>(data.value_),
+ MeasurementFetcher::number_of_get);
+ }
+ else if (opentelemetry::nostd::get<std::string>(
+ data_attr.attributes.find("RequestType")->second) == "PUT")
+ {
+ EXPECT_EQ(opentelemetry::nostd::get<long>(data.value_),
+ MeasurementFetcher::number_of_put);
+ }
+ count_attributes++;
+ }
+ return true;
+ });
+ EXPECT_EQ(MeasurementFetcher::number_of_attributes, count_attributes);
+}
+
+INSTANTIATE_TEST_SUITE_P(WritableMetricStorageTestLong,
+ WritableMetricStorageTestFixture,
+ ::testing::Values(AggregationTemporality::kCumulative,
+ AggregationTemporality::kDelta));
+
+#endif \ No newline at end of file