blob: dac8177e06ca309cb7495dbb3ff86a7e649e5d8f [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"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020012#include "test/gtest.h"
asapersson1fe48a52016-01-07 01:02:42 -080013
14namespace webrtc {
15namespace {
16const int kSample = 22;
asapersson1fe48a52016-01-07 01:02:42 -080017
18void AddSparseSample(const std::string& name, int sample) {
19 RTC_HISTOGRAM_COUNTS_SPARSE_100(name, sample);
20}
asapersson040b79f2016-02-02 07:13:01 -080021void AddSampleWithVaryingName(int index, const std::string& name, int sample) {
22 RTC_HISTOGRAMS_COUNTS_100(index, name, sample);
23}
asapersson1fe48a52016-01-07 01:02:42 -080024} // namespace
25
asapersson01d70a32016-05-20 06:29:46 -070026class MetricsTest : public ::testing::Test {
27 public:
28 MetricsTest() {}
asapersson1fe48a52016-01-07 01:02:42 -080029
asapersson01d70a32016-05-20 06:29:46 -070030 protected:
Mirko Bonadeic14d9bb2018-07-16 15:44:28 +020031 void SetUp() override { metrics::Reset(); }
asapersson01d70a32016-05-20 06:29:46 -070032};
33
34TEST_F(MetricsTest, InitiallyNoSamples) {
35 EXPECT_EQ(0, metrics::NumSamples("NonExisting"));
36 EXPECT_EQ(0, metrics::NumEvents("NonExisting", kSample));
asapersson1fe48a52016-01-07 01:02:42 -080037}
38
asapersson01d70a32016-05-20 06:29:46 -070039TEST_F(MetricsTest, RtcHistogramPercent_AddSample) {
40 const std::string kName = "Percentage";
41 RTC_HISTOGRAM_PERCENTAGE(kName, kSample);
42 EXPECT_EQ(1, metrics::NumSamples(kName));
43 EXPECT_EQ(1, metrics::NumEvents(kName, kSample));
44}
45
46TEST_F(MetricsTest, RtcHistogramEnumeration_AddSample) {
47 const std::string kName = "Enumeration";
48 RTC_HISTOGRAM_ENUMERATION(kName, kSample, kSample + 1);
49 EXPECT_EQ(1, metrics::NumSamples(kName));
50 EXPECT_EQ(1, metrics::NumEvents(kName, kSample));
51}
52
asapersson1731c9c2016-11-30 00:29:09 -080053TEST_F(MetricsTest, RtcHistogramBoolean_AddSample) {
54 const std::string kName = "Boolean";
55 const int kSample = 0;
56 RTC_HISTOGRAM_BOOLEAN(kName, kSample);
57 EXPECT_EQ(1, metrics::NumSamples(kName));
58 EXPECT_EQ(1, metrics::NumEvents(kName, kSample));
59}
60
asapersson01d70a32016-05-20 06:29:46 -070061TEST_F(MetricsTest, RtcHistogramCountsSparse_AddSample) {
62 const std::string kName = "CountsSparse100";
63 RTC_HISTOGRAM_COUNTS_SPARSE_100(kName, kSample);
64 EXPECT_EQ(1, metrics::NumSamples(kName));
65 EXPECT_EQ(1, metrics::NumEvents(kName, kSample));
66}
67
68TEST_F(MetricsTest, RtcHistogramCounts_AddSample) {
69 const std::string kName = "Counts100";
70 RTC_HISTOGRAM_COUNTS_100(kName, kSample);
71 EXPECT_EQ(1, metrics::NumSamples(kName));
72 EXPECT_EQ(1, metrics::NumEvents(kName, kSample));
73}
74
75TEST_F(MetricsTest, RtcHistogramCounts_AddMultipleSamples) {
76 const std::string kName = "Counts200";
77 const int kNumSamples = 10;
78 for (int i = 1; i <= kNumSamples; ++i) {
79 RTC_HISTOGRAM_COUNTS_200(kName, i);
80 EXPECT_EQ(1, metrics::NumEvents(kName, i));
81 EXPECT_EQ(i, metrics::NumSamples(kName));
82 }
83}
84
85TEST_F(MetricsTest, RtcHistogramsCounts_AddSample) {
asapersson040b79f2016-02-02 07:13:01 -080086 AddSampleWithVaryingName(0, "Name1", kSample);
87 AddSampleWithVaryingName(1, "Name2", kSample + 1);
88 AddSampleWithVaryingName(2, "Name3", kSample + 2);
asapersson01d70a32016-05-20 06:29:46 -070089 EXPECT_EQ(1, metrics::NumSamples("Name1"));
90 EXPECT_EQ(1, metrics::NumSamples("Name2"));
91 EXPECT_EQ(1, metrics::NumSamples("Name3"));
92 EXPECT_EQ(1, metrics::NumEvents("Name1", kSample + 0));
93 EXPECT_EQ(1, metrics::NumEvents("Name2", kSample + 1));
94 EXPECT_EQ(1, metrics::NumEvents("Name3", kSample + 2));
asapersson040b79f2016-02-02 07:13:01 -080095}
96
97#if RTC_DCHECK_IS_ON && GTEST_HAS_DEATH_TEST && !defined(WEBRTC_ANDROID)
asapersson01d70a32016-05-20 06:29:46 -070098TEST_F(MetricsTest, RtcHistogramsCounts_InvalidIndex) {
99 EXPECT_DEATH(RTC_HISTOGRAMS_COUNTS_1000(-1, "Name", kSample), "");
100 EXPECT_DEATH(RTC_HISTOGRAMS_COUNTS_1000(3, "Name", kSample), "");
101 EXPECT_DEATH(RTC_HISTOGRAMS_COUNTS_1000(3u, "Name", kSample), "");
asapersson040b79f2016-02-02 07:13:01 -0800102}
103#endif
104
asapersson01d70a32016-05-20 06:29:46 -0700105TEST_F(MetricsTest, RtcHistogramSparse_NonConstantNameWorks) {
106 AddSparseSample("Sparse1", kSample);
107 AddSparseSample("Sparse2", kSample);
108 EXPECT_EQ(1, metrics::NumSamples("Sparse1"));
109 EXPECT_EQ(1, metrics::NumSamples("Sparse2"));
asapersson1fe48a52016-01-07 01:02:42 -0800110}
111
asapersson1fe48a52016-01-07 01:02:42 -0800112} // namespace webrtc