blob: cd3807748c41ddbd325f5d4c101d62c6768177ab [file] [log] [blame]
asapersson1fe48a52016-01-07 01:02:42 -08001/*
2 * Copyright (c) 2015 The WebRTC project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020011#include "system_wrappers/include/metrics.h"
Jonas Olssona4d87372019-07-05 19:08:33 +020012
Ali Tofigh969c1352022-05-13 10:26:58 +020013#include "absl/strings/string_view.h"
Steve Antonc1e6e862019-03-04 14:43:44 -080014#include "test/gmock.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020015#include "test/gtest.h"
asapersson1fe48a52016-01-07 01:02:42 -080016
Steve Antonc1e6e862019-03-04 14:43:44 -080017using ::testing::ElementsAre;
18using ::testing::IsEmpty;
19using ::testing::Pair;
20
Ying Wangef3998f2019-12-09 13:06:53 +010021#if RTC_METRICS_ENABLED
asapersson1fe48a52016-01-07 01:02:42 -080022namespace webrtc {
23namespace {
24const int kSample = 22;
asapersson1fe48a52016-01-07 01:02:42 -080025
Ali Tofigh969c1352022-05-13 10:26:58 +020026void AddSparseSample(absl::string_view name, int sample) {
asapersson1fe48a52016-01-07 01:02:42 -080027 RTC_HISTOGRAM_COUNTS_SPARSE_100(name, sample);
28}
Ali Tofigh969c1352022-05-13 10:26:58 +020029void AddSampleWithVaryingName(int index, absl::string_view name, int sample) {
asapersson040b79f2016-02-02 07:13:01 -080030 RTC_HISTOGRAMS_COUNTS_100(index, name, sample);
31}
asapersson1fe48a52016-01-07 01:02:42 -080032} // namespace
33
asapersson01d70a32016-05-20 06:29:46 -070034class MetricsTest : public ::testing::Test {
35 public:
36 MetricsTest() {}
asapersson1fe48a52016-01-07 01:02:42 -080037
asapersson01d70a32016-05-20 06:29:46 -070038 protected:
Mirko Bonadeic14d9bb2018-07-16 15:44:28 +020039 void SetUp() override { metrics::Reset(); }
asapersson01d70a32016-05-20 06:29:46 -070040};
41
42TEST_F(MetricsTest, InitiallyNoSamples) {
43 EXPECT_EQ(0, metrics::NumSamples("NonExisting"));
44 EXPECT_EQ(0, metrics::NumEvents("NonExisting", kSample));
Steve Antonc1e6e862019-03-04 14:43:44 -080045 EXPECT_THAT(metrics::Samples("NonExisting"), IsEmpty());
asapersson1fe48a52016-01-07 01:02:42 -080046}
47
asapersson01d70a32016-05-20 06:29:46 -070048TEST_F(MetricsTest, RtcHistogramPercent_AddSample) {
49 const std::string kName = "Percentage";
50 RTC_HISTOGRAM_PERCENTAGE(kName, kSample);
51 EXPECT_EQ(1, metrics::NumSamples(kName));
52 EXPECT_EQ(1, metrics::NumEvents(kName, kSample));
Steve Antonc1e6e862019-03-04 14:43:44 -080053 EXPECT_THAT(metrics::Samples(kName), ElementsAre(Pair(kSample, 1)));
asapersson01d70a32016-05-20 06:29:46 -070054}
55
56TEST_F(MetricsTest, RtcHistogramEnumeration_AddSample) {
57 const std::string kName = "Enumeration";
58 RTC_HISTOGRAM_ENUMERATION(kName, kSample, kSample + 1);
59 EXPECT_EQ(1, metrics::NumSamples(kName));
60 EXPECT_EQ(1, metrics::NumEvents(kName, kSample));
Steve Antonc1e6e862019-03-04 14:43:44 -080061 EXPECT_THAT(metrics::Samples(kName), ElementsAre(Pair(kSample, 1)));
asapersson01d70a32016-05-20 06:29:46 -070062}
63
asapersson1731c9c2016-11-30 00:29:09 -080064TEST_F(MetricsTest, RtcHistogramBoolean_AddSample) {
65 const std::string kName = "Boolean";
66 const int kSample = 0;
67 RTC_HISTOGRAM_BOOLEAN(kName, kSample);
68 EXPECT_EQ(1, metrics::NumSamples(kName));
69 EXPECT_EQ(1, metrics::NumEvents(kName, kSample));
Steve Antonc1e6e862019-03-04 14:43:44 -080070 EXPECT_THAT(metrics::Samples(kName), ElementsAre(Pair(kSample, 1)));
asapersson1731c9c2016-11-30 00:29:09 -080071}
72
asapersson01d70a32016-05-20 06:29:46 -070073TEST_F(MetricsTest, RtcHistogramCountsSparse_AddSample) {
74 const std::string kName = "CountsSparse100";
75 RTC_HISTOGRAM_COUNTS_SPARSE_100(kName, kSample);
76 EXPECT_EQ(1, metrics::NumSamples(kName));
77 EXPECT_EQ(1, metrics::NumEvents(kName, kSample));
Steve Antonc1e6e862019-03-04 14:43:44 -080078 EXPECT_THAT(metrics::Samples(kName), ElementsAre(Pair(kSample, 1)));
asapersson01d70a32016-05-20 06:29:46 -070079}
80
81TEST_F(MetricsTest, RtcHistogramCounts_AddSample) {
82 const std::string kName = "Counts100";
83 RTC_HISTOGRAM_COUNTS_100(kName, kSample);
84 EXPECT_EQ(1, metrics::NumSamples(kName));
85 EXPECT_EQ(1, metrics::NumEvents(kName, kSample));
Steve Antonc1e6e862019-03-04 14:43:44 -080086 EXPECT_THAT(metrics::Samples(kName), ElementsAre(Pair(kSample, 1)));
asapersson01d70a32016-05-20 06:29:46 -070087}
88
89TEST_F(MetricsTest, RtcHistogramCounts_AddMultipleSamples) {
90 const std::string kName = "Counts200";
91 const int kNumSamples = 10;
Steve Antonc1e6e862019-03-04 14:43:44 -080092 std::map<int, int> samples;
asapersson01d70a32016-05-20 06:29:46 -070093 for (int i = 1; i <= kNumSamples; ++i) {
94 RTC_HISTOGRAM_COUNTS_200(kName, i);
95 EXPECT_EQ(1, metrics::NumEvents(kName, i));
96 EXPECT_EQ(i, metrics::NumSamples(kName));
Steve Antonc1e6e862019-03-04 14:43:44 -080097 samples[i] = 1;
asapersson01d70a32016-05-20 06:29:46 -070098 }
Steve Antonc1e6e862019-03-04 14:43:44 -080099 EXPECT_EQ(samples, metrics::Samples(kName));
asapersson01d70a32016-05-20 06:29:46 -0700100}
101
102TEST_F(MetricsTest, RtcHistogramsCounts_AddSample) {
asapersson040b79f2016-02-02 07:13:01 -0800103 AddSampleWithVaryingName(0, "Name1", kSample);
104 AddSampleWithVaryingName(1, "Name2", kSample + 1);
105 AddSampleWithVaryingName(2, "Name3", kSample + 2);
asapersson01d70a32016-05-20 06:29:46 -0700106 EXPECT_EQ(1, metrics::NumSamples("Name1"));
107 EXPECT_EQ(1, metrics::NumSamples("Name2"));
108 EXPECT_EQ(1, metrics::NumSamples("Name3"));
109 EXPECT_EQ(1, metrics::NumEvents("Name1", kSample + 0));
110 EXPECT_EQ(1, metrics::NumEvents("Name2", kSample + 1));
111 EXPECT_EQ(1, metrics::NumEvents("Name3", kSample + 2));
Steve Antonc1e6e862019-03-04 14:43:44 -0800112 EXPECT_THAT(metrics::Samples("Name1"), ElementsAre(Pair(kSample + 0, 1)));
113 EXPECT_THAT(metrics::Samples("Name2"), ElementsAre(Pair(kSample + 1, 1)));
114 EXPECT_THAT(metrics::Samples("Name3"), ElementsAre(Pair(kSample + 2, 1)));
asapersson040b79f2016-02-02 07:13:01 -0800115}
116
117#if RTC_DCHECK_IS_ON && GTEST_HAS_DEATH_TEST && !defined(WEBRTC_ANDROID)
Tommia5e07cc2020-05-26 21:40:37 +0200118using MetricsDeathTest = MetricsTest;
119TEST_F(MetricsDeathTest, RtcHistogramsCounts_InvalidIndex) {
asapersson01d70a32016-05-20 06:29:46 -0700120 EXPECT_DEATH(RTC_HISTOGRAMS_COUNTS_1000(-1, "Name", kSample), "");
121 EXPECT_DEATH(RTC_HISTOGRAMS_COUNTS_1000(3, "Name", kSample), "");
122 EXPECT_DEATH(RTC_HISTOGRAMS_COUNTS_1000(3u, "Name", kSample), "");
asapersson040b79f2016-02-02 07:13:01 -0800123}
124#endif
125
asapersson01d70a32016-05-20 06:29:46 -0700126TEST_F(MetricsTest, RtcHistogramSparse_NonConstantNameWorks) {
127 AddSparseSample("Sparse1", kSample);
128 AddSparseSample("Sparse2", kSample);
129 EXPECT_EQ(1, metrics::NumSamples("Sparse1"));
130 EXPECT_EQ(1, metrics::NumSamples("Sparse2"));
Steve Antonc1e6e862019-03-04 14:43:44 -0800131 EXPECT_THAT(metrics::Samples("Sparse1"), ElementsAre(Pair(kSample, 1)));
132 EXPECT_THAT(metrics::Samples("Sparse2"), ElementsAre(Pair(kSample, 1)));
asapersson1fe48a52016-01-07 01:02:42 -0800133}
134
asapersson1fe48a52016-01-07 01:02:42 -0800135} // namespace webrtc
Ying Wangef3998f2019-12-09 13:06:53 +0100136#endif