2018-02-15 23:28:38 +08:00
|
|
|
#include "stats/metrics.hpp"
|
|
|
|
|
|
|
|
#include <thread>
|
|
|
|
|
|
|
|
#include "gtest/gtest.h"
|
|
|
|
|
|
|
|
using namespace std::chrono_literals;
|
|
|
|
|
|
|
|
using namespace stats;
|
|
|
|
|
|
|
|
TEST(Metrics, Counter) {
|
|
|
|
Counter &x = GetCounter("counter");
|
|
|
|
EXPECT_EQ(*x.Flush(), 0);
|
|
|
|
EXPECT_EQ(x.Value(), 0);
|
|
|
|
x.Bump();
|
|
|
|
EXPECT_EQ(*x.Flush(), 1);
|
|
|
|
EXPECT_EQ(x.Value(), 1);
|
|
|
|
|
|
|
|
Counter &y = GetCounter("counter");
|
|
|
|
EXPECT_EQ(*y.Flush(), 1);
|
|
|
|
EXPECT_EQ(y.Value(), 1);
|
|
|
|
|
|
|
|
y.Bump(5);
|
|
|
|
EXPECT_EQ(*x.Flush(), 6);
|
|
|
|
EXPECT_EQ(x.Value(), 6);
|
|
|
|
EXPECT_EQ(*y.Flush(), 6);
|
|
|
|
EXPECT_EQ(y.Value(), 6);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(Metrics, Gauge) {
|
|
|
|
Gauge &x = GetGauge("gauge");
|
|
|
|
EXPECT_EQ(*x.Flush(), 0);
|
|
|
|
x.Set(1);
|
|
|
|
EXPECT_EQ(*x.Flush(), 1);
|
|
|
|
|
|
|
|
Gauge &y = GetGauge("gauge");
|
|
|
|
EXPECT_EQ(*y.Flush(), 1);
|
|
|
|
|
|
|
|
x.Set(2);
|
|
|
|
EXPECT_EQ(*x.Flush(), 2);
|
|
|
|
EXPECT_EQ(*y.Flush(), 2);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(Metrics, IntervalMin) {
|
|
|
|
IntervalMin &x = GetIntervalMin("min");
|
2019-04-23 17:00:49 +08:00
|
|
|
EXPECT_EQ(x.Flush(), std::nullopt);
|
2018-02-15 23:28:38 +08:00
|
|
|
x.Add(5);
|
|
|
|
x.Add(3);
|
|
|
|
EXPECT_EQ(*x.Flush(), 3);
|
2019-04-23 17:00:49 +08:00
|
|
|
EXPECT_EQ(x.Flush(), std::nullopt);
|
2018-02-15 23:28:38 +08:00
|
|
|
x.Add(3);
|
|
|
|
x.Add(5);
|
|
|
|
EXPECT_EQ(*x.Flush(), 3);
|
2019-04-23 17:00:49 +08:00
|
|
|
EXPECT_EQ(x.Flush(), std::nullopt);
|
2018-02-15 23:28:38 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(Metrics, IntervalMax) {
|
|
|
|
IntervalMax &x = GetIntervalMax("max");
|
2019-04-23 17:00:49 +08:00
|
|
|
EXPECT_EQ(x.Flush(), std::nullopt);
|
2018-02-15 23:28:38 +08:00
|
|
|
x.Add(5);
|
|
|
|
x.Add(3);
|
|
|
|
EXPECT_EQ(*x.Flush(), 5);
|
2019-04-23 17:00:49 +08:00
|
|
|
EXPECT_EQ(x.Flush(), std::nullopt);
|
2018-02-15 23:28:38 +08:00
|
|
|
x.Add(3);
|
|
|
|
x.Add(5);
|
|
|
|
EXPECT_EQ(*x.Flush(), 5);
|
2019-04-23 17:00:49 +08:00
|
|
|
EXPECT_EQ(x.Flush(), std::nullopt);
|
2018-02-15 23:28:38 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(Metrics, Stopwatch) {
|
|
|
|
auto d1 = Stopwatch("stopwatch", [] { std::this_thread::sleep_for(150ms); });
|
|
|
|
EXPECT_TRUE(140 <= d1 && d1 <= 160);
|
|
|
|
|
|
|
|
auto d2 = Stopwatch("stopwatch", [] { std::this_thread::sleep_for(300ms); });
|
|
|
|
EXPECT_TRUE(290 <= d2 && d2 <= 310);
|
|
|
|
|
|
|
|
Counter &total_time = GetCounter("stopwatch.total_time");
|
|
|
|
Counter &count = GetCounter("stopwatch.count");
|
|
|
|
IntervalMin &min = GetIntervalMin("stopwatch.min");
|
|
|
|
IntervalMax &max = GetIntervalMax("stopwatch.max");
|
|
|
|
|
|
|
|
EXPECT_TRUE(430 <= total_time.Value() && total_time.Value() <= 470);
|
|
|
|
EXPECT_EQ(count.Value(), 2);
|
|
|
|
|
|
|
|
auto m = *min.Flush();
|
|
|
|
EXPECT_TRUE(140 <= m && m <= 160);
|
|
|
|
|
|
|
|
auto M = *max.Flush();
|
|
|
|
EXPECT_TRUE(290 <= M && M <= 310);
|
|
|
|
}
|