blob: fe909e821cd7add5d0e89265f238334eb10ce298 [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"
12#include "system_wrappers/include/metrics_default.h"
13#include "test/gtest.h"
asapersson1fe48a52016-01-07 01:02:42 -080014
15namespace webrtc {
16namespace {
17const int kSample = 22;
asapersson1fe48a52016-01-07 01:02:42 -080018
19void AddSparseSample(const std::string& name, int sample) {
20 RTC_HISTOGRAM_COUNTS_SPARSE_100(name, sample);
21}
asapersson040b79f2016-02-02 07:13:01 -080022void AddSampleWithVaryingName(int index, const std::string& name, int sample) {
23 RTC_HISTOGRAMS_COUNTS_100(index, name, sample);
24}
asapersson1fe48a52016-01-07 01:02:42 -080025} // namespace
26
asapersson01d70a32016-05-20 06:29:46 -070027class MetricsTest : public ::testing::Test {
28 public:
29 MetricsTest() {}
asapersson1fe48a52016-01-07 01:02:42 -080030
asapersson01d70a32016-05-20 06:29:46 -070031 protected:
32 virtual void SetUp() {
33 metrics::Reset();
asapersson1fe48a52016-01-07 01:02:42 -080034 }
asapersson01d70a32016-05-20 06:29:46 -070035};
36
37TEST_F(MetricsTest, InitiallyNoSamples) {
38 EXPECT_EQ(0, metrics::NumSamples("NonExisting"));
39 EXPECT_EQ(0, metrics::NumEvents("NonExisting", kSample));
asapersson1fe48a52016-01-07 01:02:42 -080040}
41
asapersson01d70a32016-05-20 06:29:46 -070042TEST_F(MetricsTest, RtcHistogramPercent_AddSample) {
43 const std::string kName = "Percentage";
44 RTC_HISTOGRAM_PERCENTAGE(kName, kSample);
45 EXPECT_EQ(1, metrics::NumSamples(kName));
46 EXPECT_EQ(1, metrics::NumEvents(kName, kSample));
47}
48
49TEST_F(MetricsTest, RtcHistogramEnumeration_AddSample) {
50 const std::string kName = "Enumeration";
51 RTC_HISTOGRAM_ENUMERATION(kName, kSample, kSample + 1);
52 EXPECT_EQ(1, metrics::NumSamples(kName));
53 EXPECT_EQ(1, metrics::NumEvents(kName, kSample));
54}
55
asapersson1731c9c2016-11-30 00:29:09 -080056TEST_F(MetricsTest, RtcHistogramBoolean_AddSample) {
57 const std::string kName = "Boolean";
58 const int kSample = 0;
59 RTC_HISTOGRAM_BOOLEAN(kName, kSample);
60 EXPECT_EQ(1, metrics::NumSamples(kName));
61 EXPECT_EQ(1, metrics::NumEvents(kName, kSample));
62}
63
asapersson01d70a32016-05-20 06:29:46 -070064TEST_F(MetricsTest, RtcHistogramCountsSparse_AddSample) {
65 const std::string kName = "CountsSparse100";
66 RTC_HISTOGRAM_COUNTS_SPARSE_100(kName, kSample);
67 EXPECT_EQ(1, metrics::NumSamples(kName));
68 EXPECT_EQ(1, metrics::NumEvents(kName, kSample));
69}
70
71TEST_F(MetricsTest, RtcHistogramCounts_AddSample) {
72 const std::string kName = "Counts100";
73 RTC_HISTOGRAM_COUNTS_100(kName, kSample);
74 EXPECT_EQ(1, metrics::NumSamples(kName));
75 EXPECT_EQ(1, metrics::NumEvents(kName, kSample));
76}
77
78TEST_F(MetricsTest, RtcHistogramCounts_AddMultipleSamples) {
79 const std::string kName = "Counts200";
80 const int kNumSamples = 10;
81 for (int i = 1; i <= kNumSamples; ++i) {
82 RTC_HISTOGRAM_COUNTS_200(kName, i);
83 EXPECT_EQ(1, metrics::NumEvents(kName, i));
84 EXPECT_EQ(i, metrics::NumSamples(kName));
85 }
86}
87
88TEST_F(MetricsTest, RtcHistogramsCounts_AddSample) {
asapersson040b79f2016-02-02 07:13:01 -080089 AddSampleWithVaryingName(0, "Name1", kSample);
90 AddSampleWithVaryingName(1, "Name2", kSample + 1);
91 AddSampleWithVaryingName(2, "Name3", kSample + 2);
asapersson01d70a32016-05-20 06:29:46 -070092 EXPECT_EQ(1, metrics::NumSamples("Name1"));
93 EXPECT_EQ(1, metrics::NumSamples("Name2"));
94 EXPECT_EQ(1, metrics::NumSamples("Name3"));
95 EXPECT_EQ(1, metrics::NumEvents("Name1", kSample + 0));
96 EXPECT_EQ(1, metrics::NumEvents("Name2", kSample + 1));
97 EXPECT_EQ(1, metrics::NumEvents("Name3", kSample + 2));
asapersson040b79f2016-02-02 07:13:01 -080098}
99
100#if RTC_DCHECK_IS_ON && GTEST_HAS_DEATH_TEST && !defined(WEBRTC_ANDROID)
asapersson01d70a32016-05-20 06:29:46 -0700101TEST_F(MetricsTest, RtcHistogramsCounts_InvalidIndex) {
102 EXPECT_DEATH(RTC_HISTOGRAMS_COUNTS_1000(-1, "Name", kSample), "");
103 EXPECT_DEATH(RTC_HISTOGRAMS_COUNTS_1000(3, "Name", kSample), "");
104 EXPECT_DEATH(RTC_HISTOGRAMS_COUNTS_1000(3u, "Name", kSample), "");
asapersson040b79f2016-02-02 07:13:01 -0800105}
106#endif
107
asapersson01d70a32016-05-20 06:29:46 -0700108TEST_F(MetricsTest, RtcHistogramSparse_NonConstantNameWorks) {
109 AddSparseSample("Sparse1", kSample);
110 AddSparseSample("Sparse2", kSample);
111 EXPECT_EQ(1, metrics::NumSamples("Sparse1"));
112 EXPECT_EQ(1, metrics::NumSamples("Sparse2"));
asapersson1fe48a52016-01-07 01:02:42 -0800113}
114
asapersson1fe48a52016-01-07 01:02:42 -0800115} // namespace webrtc