blob: d7be2297f82aa4adc6514b893a9c106b52e7c1df [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
asapersson1fe48a52016-01-07 01:02:42 -080011#include "webrtc/system_wrappers/include/metrics.h"
asapersson01d70a32016-05-20 06:29:46 -070012#include "webrtc/system_wrappers/include/metrics_default.h"
kwibergac9f8762016-09-30 22:29:43 -070013#include "webrtc/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}
asapersson01d70a32016-05-20 06:29:46 -070025#if RTC_DCHECK_IS_ON && GTEST_HAS_DEATH_TEST && !defined(WEBRTC_ANDROID)
asapersson1fe48a52016-01-07 01:02:42 -080026void AddSample(const std::string& name, int sample) {
27 RTC_HISTOGRAM_COUNTS_100(name, sample);
28}
asapersson01d70a32016-05-20 06:29:46 -070029#endif // RTC_DCHECK_IS_ON && GTEST_HAS_DEATH_TEST && !defined(WEBRTC_ANDROID)
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:
37 virtual void SetUp() {
38 metrics::Reset();
asapersson1fe48a52016-01-07 01:02:42 -080039 }
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));
asapersson1fe48a52016-01-07 01:02:42 -080045}
46
asapersson01d70a32016-05-20 06:29:46 -070047TEST_F(MetricsTest, RtcHistogramPercent_AddSample) {
48 const std::string kName = "Percentage";
49 RTC_HISTOGRAM_PERCENTAGE(kName, kSample);
50 EXPECT_EQ(1, metrics::NumSamples(kName));
51 EXPECT_EQ(1, metrics::NumEvents(kName, kSample));
52}
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));
59}
60
asapersson1731c9c2016-11-30 00:29:09 -080061TEST_F(MetricsTest, RtcHistogramBoolean_AddSample) {
62 const std::string kName = "Boolean";
63 const int kSample = 0;
64 RTC_HISTOGRAM_BOOLEAN(kName, kSample);
65 EXPECT_EQ(1, metrics::NumSamples(kName));
66 EXPECT_EQ(1, metrics::NumEvents(kName, kSample));
67}
68
asapersson01d70a32016-05-20 06:29:46 -070069TEST_F(MetricsTest, RtcHistogramCountsSparse_AddSample) {
70 const std::string kName = "CountsSparse100";
71 RTC_HISTOGRAM_COUNTS_SPARSE_100(kName, kSample);
72 EXPECT_EQ(1, metrics::NumSamples(kName));
73 EXPECT_EQ(1, metrics::NumEvents(kName, kSample));
74}
75
76TEST_F(MetricsTest, RtcHistogramCounts_AddSample) {
77 const std::string kName = "Counts100";
78 RTC_HISTOGRAM_COUNTS_100(kName, kSample);
79 EXPECT_EQ(1, metrics::NumSamples(kName));
80 EXPECT_EQ(1, metrics::NumEvents(kName, kSample));
81}
82
83TEST_F(MetricsTest, RtcHistogramCounts_AddMultipleSamples) {
84 const std::string kName = "Counts200";
85 const int kNumSamples = 10;
86 for (int i = 1; i <= kNumSamples; ++i) {
87 RTC_HISTOGRAM_COUNTS_200(kName, i);
88 EXPECT_EQ(1, metrics::NumEvents(kName, i));
89 EXPECT_EQ(i, metrics::NumSamples(kName));
90 }
91}
92
93TEST_F(MetricsTest, RtcHistogramsCounts_AddSample) {
asapersson040b79f2016-02-02 07:13:01 -080094 AddSampleWithVaryingName(0, "Name1", kSample);
95 AddSampleWithVaryingName(1, "Name2", kSample + 1);
96 AddSampleWithVaryingName(2, "Name3", kSample + 2);
asapersson01d70a32016-05-20 06:29:46 -070097 EXPECT_EQ(1, metrics::NumSamples("Name1"));
98 EXPECT_EQ(1, metrics::NumSamples("Name2"));
99 EXPECT_EQ(1, metrics::NumSamples("Name3"));
100 EXPECT_EQ(1, metrics::NumEvents("Name1", kSample + 0));
101 EXPECT_EQ(1, metrics::NumEvents("Name2", kSample + 1));
102 EXPECT_EQ(1, metrics::NumEvents("Name3", kSample + 2));
asapersson040b79f2016-02-02 07:13:01 -0800103}
104
105#if RTC_DCHECK_IS_ON && GTEST_HAS_DEATH_TEST && !defined(WEBRTC_ANDROID)
asapersson01d70a32016-05-20 06:29:46 -0700106TEST_F(MetricsTest, RtcHistogramsCounts_InvalidIndex) {
107 EXPECT_DEATH(RTC_HISTOGRAMS_COUNTS_1000(-1, "Name", kSample), "");
108 EXPECT_DEATH(RTC_HISTOGRAMS_COUNTS_1000(3, "Name", kSample), "");
109 EXPECT_DEATH(RTC_HISTOGRAMS_COUNTS_1000(3u, "Name", kSample), "");
asapersson040b79f2016-02-02 07:13:01 -0800110}
111#endif
112
asapersson01d70a32016-05-20 06:29:46 -0700113TEST_F(MetricsTest, RtcHistogramSparse_NonConstantNameWorks) {
114 AddSparseSample("Sparse1", kSample);
115 AddSparseSample("Sparse2", kSample);
116 EXPECT_EQ(1, metrics::NumSamples("Sparse1"));
117 EXPECT_EQ(1, metrics::NumSamples("Sparse2"));
asapersson1fe48a52016-01-07 01:02:42 -0800118}
119
asapersson01d70a32016-05-20 06:29:46 -0700120#if RTC_DCHECK_IS_ON && GTEST_HAS_DEATH_TEST && !defined(WEBRTC_ANDROID)
121TEST_F(MetricsTest, RtcHistogram_FailsForNonConstantName) {
122 AddSample("ConstantName1", kSample);
123 EXPECT_DEATH(AddSample("NotConstantName1", kSample), "");
asapersson1fe48a52016-01-07 01:02:42 -0800124}
asapersson01d70a32016-05-20 06:29:46 -0700125#endif
asapersson1fe48a52016-01-07 01:02:42 -0800126
127} // namespace webrtc