Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(451)

Side by Side Diff: webrtc/system_wrappers/source/metrics_unittest.cc

Issue 1915523002: Add a default implementation in metrics_default.cc of histograms methods in system_wrappers/interfac (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: Created 4 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright (c) 2015 The WebRTC project authors. All Rights Reserved. 2 * Copyright (c) 2015 The WebRTC project authors. All Rights Reserved.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license 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 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 6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may 7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree. 8 * be found in the AUTHORS file in the root of the source tree.
9 */ 9 */
10 10
11 #include "testing/gtest/include/gtest/gtest.h" 11 #include "testing/gtest/include/gtest/gtest.h"
12 12
13 #include "webrtc/system_wrappers/include/metrics.h" 13 #include "webrtc/system_wrappers/include/metrics.h"
14 #include "webrtc/test/histogram.h" 14 #include "webrtc/system_wrappers/include/metrics_default.h"
15 15
16 namespace webrtc { 16 namespace webrtc {
17 namespace { 17 namespace {
18 const int kSample = 22; 18 const int kSample = 22;
19 const std::string kName = "Name";
20 19
21 void AddSparseSample(const std::string& name, int sample) { 20 void AddSparseSample(const std::string& name, int sample) {
22 RTC_HISTOGRAM_COUNTS_SPARSE_100(name, sample); 21 RTC_HISTOGRAM_COUNTS_SPARSE_100(name, sample);
23 } 22 }
24 void AddSampleWithVaryingName(int index, const std::string& name, int sample) { 23 void AddSampleWithVaryingName(int index, const std::string& name, int sample) {
25 RTC_HISTOGRAMS_COUNTS_100(index, name, sample); 24 RTC_HISTOGRAMS_COUNTS_100(index, name, sample);
26 } 25 }
27 #if GTEST_HAS_DEATH_TEST && !defined(WEBRTC_ANDROID) 26 #if RTC_DCHECK_IS_ON && GTEST_HAS_DEATH_TEST && !defined(WEBRTC_ANDROID)
28 void AddSample(const std::string& name, int sample) { 27 void AddSample(const std::string& name, int sample) {
29 RTC_HISTOGRAM_COUNTS_100(name, sample); 28 RTC_HISTOGRAM_COUNTS_100(name, sample);
30 } 29 }
31 #endif // GTEST_HAS_DEATH_TEST && !defined(WEBRTC_ANDROID) 30 #endif // RTC_DCHECK_IS_ON && GTEST_HAS_DEATH_TEST && !defined(WEBRTC_ANDROID)
32 } // namespace 31 } // namespace
33 32
34 TEST(MetricsTest, InitiallyNoSamples) { 33 class MetricsTest : public ::testing::Test {
35 test::ClearHistograms(); 34 public:
36 EXPECT_EQ(0, test::NumHistogramSamples(kName)); 35 MetricsTest() {}
37 EXPECT_EQ(-1, test::LastHistogramSample(kName)); 36
37 protected:
38 virtual void SetUp() {
39 metrics::Reset();
40 }
41 };
42
43 TEST_F(MetricsTest, InitiallyNoSamples) {
44 EXPECT_EQ(0, metrics::NumSamples("NonExisting"));
45 EXPECT_EQ(0, metrics::NumEvents("NonExisting", kSample));
38 } 46 }
39 47
40 TEST(MetricsTest, RtcHistogramPercent_AddSample) { 48 TEST_F(MetricsTest, RtcHistogramPercent_AddSample) {
41 test::ClearHistograms(); 49 const std::string kName = "Percentage";
42 RTC_HISTOGRAM_PERCENTAGE(kName, kSample); 50 RTC_HISTOGRAM_PERCENTAGE(kName, kSample);
43 EXPECT_EQ(1, test::NumHistogramSamples(kName)); 51 EXPECT_EQ(1, metrics::NumSamples(kName));
44 EXPECT_EQ(kSample, test::LastHistogramSample(kName)); 52 EXPECT_EQ(1, metrics::NumEvents(kName, kSample));
45 } 53 }
46 54
47 TEST(MetricsTest, RtcHistogramEnumeration_AddSample) { 55 TEST_F(MetricsTest, RtcHistogramEnumeration_AddSample) {
48 test::ClearHistograms(); 56 const std::string kName = "Enumeration";
49 RTC_HISTOGRAM_ENUMERATION(kName, kSample, kSample + 1); 57 RTC_HISTOGRAM_ENUMERATION(kName, kSample, kSample + 1);
50 EXPECT_EQ(1, test::NumHistogramSamples(kName)); 58 EXPECT_EQ(1, metrics::NumSamples(kName));
51 EXPECT_EQ(kSample, test::LastHistogramSample(kName)); 59 EXPECT_EQ(1, metrics::NumEvents(kName, kSample));
52 } 60 }
53 61
54 TEST(MetricsTest, RtcHistogramCountsSparse_AddSample) { 62 TEST_F(MetricsTest, RtcHistogramCountsSparse_AddSample) {
55 test::ClearHistograms(); 63 const std::string kName = "CountsSparse100";
56 RTC_HISTOGRAM_COUNTS_SPARSE_100(kName, kSample); 64 RTC_HISTOGRAM_COUNTS_SPARSE_100(kName, kSample);
57 EXPECT_EQ(1, test::NumHistogramSamples(kName)); 65 EXPECT_EQ(1, metrics::NumSamples(kName));
58 EXPECT_EQ(kSample, test::LastHistogramSample(kName)); 66 EXPECT_EQ(1, metrics::NumEvents(kName, kSample));
59 } 67 }
60 68
61 TEST(MetricsTest, RtcHistogramCounts_AddSample) { 69 TEST_F(MetricsTest, RtcHistogramCounts_AddSample) {
62 test::ClearHistograms(); 70 const std::string kName = "Counts100";
63 RTC_HISTOGRAM_COUNTS_100(kName, kSample); 71 RTC_HISTOGRAM_COUNTS_100(kName, kSample);
64 EXPECT_EQ(1, test::NumHistogramSamples(kName)); 72 EXPECT_EQ(1, metrics::NumSamples(kName));
65 EXPECT_EQ(kSample, test::LastHistogramSample(kName)); 73 EXPECT_EQ(1, metrics::NumEvents(kName, kSample));
66 } 74 }
67 75
68 TEST(MetricsTest, RtcHistogramCounts_AddMultipleSamples) { 76 TEST_F(MetricsTest, RtcHistogramCounts_AddMultipleSamples) {
69 test::ClearHistograms(); 77 const std::string kName = "Counts200";
70 const int kNumSamples = 10; 78 const int kNumSamples = 10;
71 for (int i = 0; i < kNumSamples; ++i) { 79 for (int i = 1; i <= kNumSamples; ++i) {
72 RTC_HISTOGRAM_COUNTS_100(kName, i); 80 RTC_HISTOGRAM_COUNTS_200(kName, i);
81 EXPECT_EQ(1, metrics::NumEvents(kName, i));
82 EXPECT_EQ(i, metrics::NumSamples(kName));
73 } 83 }
74 EXPECT_EQ(kNumSamples, test::NumHistogramSamples(kName));
75 EXPECT_EQ(kNumSamples - 1, test::LastHistogramSample(kName));
76 } 84 }
77 85
78 TEST(MetricsTest, RtcHistogramsCounts_AddSample) { 86 TEST_F(MetricsTest, RtcHistogramsCounts_AddSample) {
79 test::ClearHistograms();
80 AddSampleWithVaryingName(0, "Name1", kSample); 87 AddSampleWithVaryingName(0, "Name1", kSample);
81 AddSampleWithVaryingName(1, "Name2", kSample + 1); 88 AddSampleWithVaryingName(1, "Name2", kSample + 1);
82 AddSampleWithVaryingName(2, "Name3", kSample + 2); 89 AddSampleWithVaryingName(2, "Name3", kSample + 2);
83 EXPECT_EQ(1, test::NumHistogramSamples("Name1")); 90 EXPECT_EQ(1, metrics::NumSamples("Name1"));
84 EXPECT_EQ(1, test::NumHistogramSamples("Name2")); 91 EXPECT_EQ(1, metrics::NumSamples("Name2"));
85 EXPECT_EQ(1, test::NumHistogramSamples("Name3")); 92 EXPECT_EQ(1, metrics::NumSamples("Name3"));
86 EXPECT_EQ(kSample + 0, test::LastHistogramSample("Name1")); 93 EXPECT_EQ(1, metrics::NumEvents("Name1", kSample + 0));
87 EXPECT_EQ(kSample + 1, test::LastHistogramSample("Name2")); 94 EXPECT_EQ(1, metrics::NumEvents("Name2", kSample + 1));
88 EXPECT_EQ(kSample + 2, test::LastHistogramSample("Name3")); 95 EXPECT_EQ(1, metrics::NumEvents("Name3", kSample + 2));
89 } 96 }
90 97
91 #if RTC_DCHECK_IS_ON && GTEST_HAS_DEATH_TEST && !defined(WEBRTC_ANDROID) 98 #if RTC_DCHECK_IS_ON && GTEST_HAS_DEATH_TEST && !defined(WEBRTC_ANDROID)
92 TEST(MetricsTest, RtcHistogramsCounts_InvalidIndex) { 99 TEST_F(MetricsTest, RtcHistogramsCounts_InvalidIndex) {
93 EXPECT_DEATH(RTC_HISTOGRAMS_COUNTS_1000(-1, kName, kSample), ""); 100 EXPECT_DEATH(RTC_HISTOGRAMS_COUNTS_1000(-1, "Name", kSample), "");
94 EXPECT_DEATH(RTC_HISTOGRAMS_COUNTS_1000(3, kName, kSample), ""); 101 EXPECT_DEATH(RTC_HISTOGRAMS_COUNTS_1000(3, "Name", kSample), "");
95 EXPECT_DEATH(RTC_HISTOGRAMS_COUNTS_1000(3u, kName, kSample), ""); 102 EXPECT_DEATH(RTC_HISTOGRAMS_COUNTS_1000(3u, "Name", kSample), "");
96 } 103 }
97 #endif 104 #endif
98 105
99 TEST(MetricsTest, RtcHistogramSparse_NonConstantNameWorks) { 106 TEST_F(MetricsTest, RtcHistogramSparse_NonConstantNameWorks) {
100 test::ClearHistograms(); 107 AddSparseSample("Sparse1", kSample);
101 AddSparseSample("Name1", kSample); 108 AddSparseSample("Sparse2", kSample);
102 AddSparseSample("Name2", kSample); 109 EXPECT_EQ(1, metrics::NumSamples("Sparse1"));
103 EXPECT_EQ(1, test::NumHistogramSamples("Name1")); 110 EXPECT_EQ(1, metrics::NumSamples("Sparse2"));
104 EXPECT_EQ(1, test::NumHistogramSamples("Name2"));
105 } 111 }
106 112
107 #if GTEST_HAS_DEATH_TEST && !defined(WEBRTC_ANDROID) 113 #if RTC_DCHECK_IS_ON && GTEST_HAS_DEATH_TEST && !defined(WEBRTC_ANDROID)
108 TEST(MetricsTest, RtcHistogram_FailsForNonConstantName) { 114 TEST_F(MetricsTest, RtcHistogram_FailsForNonConstantName) {
109 test::ClearHistograms(); 115 AddSample("ConstantName1", kSample);
110 AddSample("Name1", kSample); 116 EXPECT_DEATH(AddSample("NotConstantName1", kSample), "");
111 EXPECT_DEATH(AddSample("Name2", kSample), "");
112 } 117 }
113 #endif // GTEST_HAS_DEATH_TEST && !defined(WEBRTC_ANDROID) 118 #endif
114 119
115 } // namespace webrtc 120 } // namespace webrtc
OLDNEW
« no previous file with comments | « webrtc/system_wrappers/source/metrics_default_unittest.cc ('k') | webrtc/system_wrappers/system_wrappers.gyp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698