summaryrefslogtreecommitdiffstats
path: root/src/jaegertracing/opentelemetry-cpp/sdk/test/metrics/metric_reader_test.cc
blob: c9c30853df6be7d2470342609c2ccfd9c538ca54 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
// Copyright The OpenTelemetry Authors
// SPDX-License-Identifier: Apache-2.0

#ifndef ENABLE_METRICS_PREVIEW
#  include "opentelemetry/sdk/metrics/metric_reader.h"
#  include <gtest/gtest.h>
#  include "opentelemetry/sdk/metrics/meter_context.h"
#  include "opentelemetry/sdk/metrics/metric_exporter.h"

using namespace opentelemetry;
using namespace opentelemetry::sdk::instrumentationlibrary;
using namespace opentelemetry::sdk::metrics;

class MockMetricReader : public MetricReader
{
public:
  MockMetricReader(AggregationTemporality aggr_temporality) : MetricReader(aggr_temporality) {}

  virtual bool OnForceFlush(std::chrono::microseconds timeout) noexcept override { return true; }
  virtual bool OnShutDown(std::chrono::microseconds timeout) noexcept override { return true; }
  virtual void OnInitialized() noexcept override {}
};

TEST(MetricReaderTest, BasicTests)
{
  AggregationTemporality aggr_temporality = AggregationTemporality::kDelta;
  std::unique_ptr<MetricReader> metric_reader1(new MockMetricReader(aggr_temporality));
  EXPECT_EQ(metric_reader1->GetAggregationTemporality(), aggr_temporality);

  std::shared_ptr<MeterContext> meter_context1(new MeterContext());
  EXPECT_NO_THROW(meter_context1->AddMetricReader(std::move(metric_reader1)));

  std::unique_ptr<MetricReader> metric_reader2(new MockMetricReader(aggr_temporality));
  std::shared_ptr<MeterContext> meter_context2(new MeterContext());
  MetricProducer *metric_producer =
      new MetricCollector(std::move(meter_context2), std::move(metric_reader2));
  EXPECT_NO_THROW(metric_producer->Collect([](ResourceMetrics &metric_data) { return true; }));
}
#endif