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 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106
|
#include "prometheus/summary.h"
#include <gtest/gtest.h>
#include <chrono>
#include <cmath>
#include <limits>
#include <memory>
#include <thread>
namespace prometheus {
namespace {
TEST(SummaryTest, initialize_with_zero) {
Summary summary{Summary::Quantiles{}};
auto metric = summary.Collect();
auto s = metric.summary;
EXPECT_EQ(s.sample_count, 0U);
EXPECT_EQ(s.sample_sum, 0);
}
TEST(SummaryTest, sample_count) {
Summary summary{Summary::Quantiles{{0.5, 0.05}}};
summary.Observe(0);
summary.Observe(200);
auto metric = summary.Collect();
auto s = metric.summary;
EXPECT_EQ(s.sample_count, 2U);
}
TEST(SummaryTest, sample_sum) {
Summary summary{Summary::Quantiles{{0.5, 0.05}}};
summary.Observe(0);
summary.Observe(1);
summary.Observe(101);
auto metric = summary.Collect();
auto s = metric.summary;
EXPECT_EQ(s.sample_sum, 102);
}
TEST(SummaryTest, quantile_size) {
Summary summary{Summary::Quantiles{{0.5, 0.05}, {0.90, 0.01}}};
auto metric = summary.Collect();
auto s = metric.summary;
EXPECT_EQ(s.quantile.size(), 2U);
}
TEST(SummaryTest, quantile_bounds) {
Summary summary{Summary::Quantiles{{0.5, 0.05}, {0.90, 0.01}, {0.99, 0.001}}};
auto metric = summary.Collect();
auto s = metric.summary;
ASSERT_EQ(s.quantile.size(), 3U);
EXPECT_DOUBLE_EQ(s.quantile.at(0).quantile, 0.5);
EXPECT_DOUBLE_EQ(s.quantile.at(1).quantile, 0.9);
EXPECT_DOUBLE_EQ(s.quantile.at(2).quantile, 0.99);
}
TEST(SummaryTest, quantile_values) {
static const int SAMPLES = 100000;
Summary summary{Summary::Quantiles{{0.5, 0.05}, {0.9, 0.01}, {0.99, 0.001}},
std::chrono::hours{1}}; // prevent rotation on slow CPUs
for (int i = 1; i <= SAMPLES; ++i) summary.Observe(i);
auto metric = summary.Collect();
auto s = metric.summary;
ASSERT_EQ(s.quantile.size(), 3U);
EXPECT_NEAR(s.quantile.at(0).value, 0.5 * SAMPLES, 0.05 * SAMPLES);
EXPECT_NEAR(s.quantile.at(1).value, 0.9 * SAMPLES, 0.01 * SAMPLES);
EXPECT_NEAR(s.quantile.at(2).value, 0.99 * SAMPLES, 0.001 * SAMPLES);
}
TEST(SummaryTest, max_age) {
Summary summary{Summary::Quantiles{{0.99, 0.001}}, std::chrono::seconds(1),
2};
summary.Observe(8.0);
const auto test_value = [&summary](double ref) {
auto metric = summary.Collect();
auto s = metric.summary;
ASSERT_EQ(s.quantile.size(), 1U);
if (std::isnan(ref))
EXPECT_TRUE(std::isnan(s.quantile.at(0).value));
else
EXPECT_DOUBLE_EQ(s.quantile.at(0).value, ref);
};
test_value(8.0);
std::this_thread::sleep_for(std::chrono::milliseconds(600));
test_value(8.0);
std::this_thread::sleep_for(std::chrono::milliseconds(600));
test_value(std::numeric_limits<double>::quiet_NaN());
}
TEST(SummaryTest, construction_with_dynamic_quantile_vector) {
auto quantiles = Summary::Quantiles{{0.99, 0.001}};
quantiles.push_back({0.5, 0.05});
Summary summary{quantiles, std::chrono::seconds(1), 2};
summary.Observe(8.0);
}
} // namespace
} // namespace prometheus
|