blob: fa8bb2da1c61613725741576b615e7f95077c5e0 [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
Steve Antonc1e6e862019-03-04 14:43:44 -080013#include "test/gmock.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020014#include "test/gtest.h"
asapersson1fe48a52016-01-07 01:02:42 -080015
Steve Antonc1e6e862019-03-04 14:43:44 -080016using ::testing::ElementsAre;
17using ::testing::IsEmpty;
18using ::testing::Pair;
19
asapersson1fe48a52016-01-07 01:02:42 -080020namespace webrtc {
21namespace {
22const int kSample = 22;
asapersson1fe48a52016-01-07 01:02:42 -080023
24void AddSparseSample(const std::string& name, int sample) {
25 RTC_HISTOGRAM_COUNTS_SPARSE_100(name, sample);
26}
asapersson040b79f2016-02-02 07:13:01 -080027void AddSampleWithVaryingName(int index, const std::string& name, int sample) {
28 RTC_HISTOGRAMS_COUNTS_100(index, name, sample);
29}
asapersson1fe48a52016-01-07 01:02:42 -080030} // namespace
31
asapersson01d70a32016-05-20 06:29:46 -070032class MetricsTest : public ::testing::Test {
33 public:
34 MetricsTest() {}
asapersson1fe48a52016-01-07 01:02:42 -080035
asapersson01d70a32016-05-20 06:29:46 -070036 protected:
Mirko Bonadeic14d9bb2018-07-16 15:44:28 +020037 void SetUp() override { metrics::Reset(); }
asapersson01d70a32016-05-20 06:29:46 -070038};
39
40TEST_F(MetricsTest, InitiallyNoSamples) {
41 EXPECT_EQ(0, metrics::NumSamples("NonExisting"));
42 EXPECT_EQ(0, metrics::NumEvents("NonExisting", kSample));
Steve Antonc1e6e862019-03-04 14:43:44 -080043 EXPECT_THAT(metrics::Samples("NonExisting"), IsEmpty());
asapersson1fe48a52016-01-07 01:02:42 -080044}
45
asapersson01d70a32016-05-20 06:29:46 -070046TEST_F(MetricsTest, RtcHistogramPercent_AddSample) {
47 const std::string kName = "Percentage";
48 RTC_HISTOGRAM_PERCENTAGE(kName, kSample);
49 EXPECT_EQ(1, metrics::NumSamples(kName));
50 EXPECT_EQ(1, metrics::NumEvents(kName, kSample));
Steve Antonc1e6e862019-03-04 14:43:44 -080051 EXPECT_THAT(metrics::Samples(kName), ElementsAre(Pair(kSample, 1)));
asapersson01d70a32016-05-20 06:29:46 -070052}
53
54TEST_F(MetricsTest, RtcHistogramEnumeration_AddSample) {
55 const std::string kName = "Enumeration";
56 RTC_HISTOGRAM_ENUMERATION(kName, kSample, kSample + 1);
57 EXPECT_EQ(1, metrics::NumSamples(kName));
58 EXPECT_EQ(1, metrics::NumEvents(kName, kSample));
Steve Antonc1e6e862019-03-04 14:43:44 -080059 EXPECT_THAT(metrics::Samples(kName), ElementsAre(Pair(kSample, 1)));
asapersson01d70a32016-05-20 06:29:46 -070060}
61
asapersson1731c9c2016-11-30 00:29:09 -080062TEST_F(MetricsTest, RtcHistogramBoolean_AddSample) {
63 const std::string kName = "Boolean";
64 const int kSample = 0;
65 RTC_HISTOGRAM_BOOLEAN(kName, kSample);
66 EXPECT_EQ(1, metrics::NumSamples(kName));
67 EXPECT_EQ(1, metrics::NumEvents(kName, kSample));
Steve Antonc1e6e862019-03-04 14:43:44 -080068 EXPECT_THAT(metrics::Samples(kName), ElementsAre(Pair(kSample, 1)));
asapersson1731c9c2016-11-30 00:29:09 -080069}
70
asapersson01d70a32016-05-20 06:29:46 -070071TEST_F(MetricsTest, RtcHistogramCountsSparse_AddSample) {
72 const std::string kName = "CountsSparse100";
73 RTC_HISTOGRAM_COUNTS_SPARSE_100(kName, kSample);
74 EXPECT_EQ(1, metrics::NumSamples(kName));
75 EXPECT_EQ(1, metrics::NumEvents(kName, kSample));
Steve Antonc1e6e862019-03-04 14:43:44 -080076 EXPECT_THAT(metrics::Samples(kName), ElementsAre(Pair(kSample, 1)));
asapersson01d70a32016-05-20 06:29:46 -070077}
78
79TEST_F(MetricsTest, RtcHistogramCounts_AddSample) {
80 const std::string kName = "Counts100";
81 RTC_HISTOGRAM_COUNTS_100(kName, kSample);
82 EXPECT_EQ(1, metrics::NumSamples(kName));
83 EXPECT_EQ(1, metrics::NumEvents(kName, kSample));
Steve Antonc1e6e862019-03-04 14:43:44 -080084 EXPECT_THAT(metrics::Samples(kName), ElementsAre(Pair(kSample, 1)));
asapersson01d70a32016-05-20 06:29:46 -070085}
86
87TEST_F(MetricsTest, RtcHistogramCounts_AddMultipleSamples) {
88 const std::string kName = "Counts200";
89 const int kNumSamples = 10;
Steve Antonc1e6e862019-03-04 14:43:44 -080090 std::map<int, int> samples;
asapersson01d70a32016-05-20 06:29:46 -070091 for (int i = 1; i <= kNumSamples; ++i) {
92 RTC_HISTOGRAM_COUNTS_200(kName, i);
93 EXPECT_EQ(1, metrics::NumEvents(kName, i));
94 EXPECT_EQ(i, metrics::NumSamples(kName));
Steve Antonc1e6e862019-03-04 14:43:44 -080095 samples[i] = 1;
asapersson01d70a32016-05-20 06:29:46 -070096 }
Steve Antonc1e6e862019-03-04 14:43:44 -080097 EXPECT_EQ(samples, metrics::Samples(kName));
asapersson01d70a32016-05-20 06:29:46 -070098}
99
100TEST_F(MetricsTest, RtcHistogramsCounts_AddSample) {
asapersson040b79f2016-02-02 07:13:01 -0800101 AddSampleWithVaryingName(0, "Name1", kSample);
102 AddSampleWithVaryingName(1, "Name2", kSample + 1);
103 AddSampleWithVaryingName(2, "Name3", kSample + 2);
asapersson01d70a32016-05-20 06:29:46 -0700104 EXPECT_EQ(1, metrics::NumSamples("Name1"));
105 EXPECT_EQ(1, metrics::NumSamples("Name2"));
106 EXPECT_EQ(1, metrics::NumSamples("Name3"));
107 EXPECT_EQ(1, metrics::NumEvents("Name1", kSample + 0));
108 EXPECT_EQ(1, metrics::NumEvents("Name2", kSample + 1));
109 EXPECT_EQ(1, metrics::NumEvents("Name3", kSample + 2));
Steve Antonc1e6e862019-03-04 14:43:44 -0800110 EXPECT_THAT(metrics::Samples("Name1"), ElementsAre(Pair(kSample + 0, 1)));
111 EXPECT_THAT(metrics::Samples("Name2"), ElementsAre(Pair(kSample + 1, 1)));
112 EXPECT_THAT(metrics::Samples("Name3"), ElementsAre(Pair(kSample + 2, 1)));
asapersson040b79f2016-02-02 07:13:01 -0800113}
114
115#if RTC_DCHECK_IS_ON && GTEST_HAS_DEATH_TEST && !defined(WEBRTC_ANDROID)
asapersson01d70a32016-05-20 06:29:46 -0700116TEST_F(MetricsTest, RtcHistogramsCounts_InvalidIndex) {
117 EXPECT_DEATH(RTC_HISTOGRAMS_COUNTS_1000(-1, "Name", kSample), "");
118 EXPECT_DEATH(RTC_HISTOGRAMS_COUNTS_1000(3, "Name", kSample), "");
119 EXPECT_DEATH(RTC_HISTOGRAMS_COUNTS_1000(3u, "Name", kSample), "");
asapersson040b79f2016-02-02 07:13:01 -0800120}
121#endif
122
asapersson01d70a32016-05-20 06:29:46 -0700123TEST_F(MetricsTest, RtcHistogramSparse_NonConstantNameWorks) {
124 AddSparseSample("Sparse1", kSample);
125 AddSparseSample("Sparse2", kSample);
126 EXPECT_EQ(1, metrics::NumSamples("Sparse1"));
127 EXPECT_EQ(1, metrics::NumSamples("Sparse2"));
Steve Antonc1e6e862019-03-04 14:43:44 -0800128 EXPECT_THAT(metrics::Samples("Sparse1"), ElementsAre(Pair(kSample, 1)));
129 EXPECT_THAT(metrics::Samples("Sparse2"), ElementsAre(Pair(kSample, 1)));
asapersson1fe48a52016-01-07 01:02:42 -0800130}
131
asapersson1fe48a52016-01-07 01:02:42 -0800132} // namespace webrtc