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

Side by Side Diff: components/metrics/data_use_tracker_unittest.cc

Issue 1818613002: Implement UMA log throttling for cellular connections (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: singleton pattern removed Created 4 years, 8 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
(Empty)
1 // Copyright 2014 The Chromium Authors. All rights reserved.
Alexei Svitkine (slow) 2016/03/29 16:29:10 2016
gayane -on leave until 09-2017 2016/03/31 01:38:24 Done.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "components/metrics/data_use_tracker.h"
6
7 #include "base/strings/stringprintf.h"
8 #include "components/metrics/metrics_pref_names.h"
9 #include "components/prefs/pref_registry_simple.h"
10 #include "components/prefs/testing_pref_service.h"
11 #include "testing/gtest/include/gtest/gtest.h"
12
13 namespace metrics {
14
15 namespace {
16 const char kTodayStr[] = "2016-03-16";
17 const char kYesterdayStr[] = "2016-03-15";
18 const char kExpiredDateStr1[] = "2016-03-09";
19 const char kExpiredDateStr2[] = "2016-03-01";
20
21 class TestDataUsePrefService : public TestingPrefServiceSimple {
22 public:
23 TestDataUsePrefService() {
24 registry()->RegisterDictionaryPref(metrics::prefs::kUserCellDataUse);
25 registry()->RegisterDictionaryPref(metrics::prefs::kUmaCellDataUse);
26 }
27
28 void ClearDataUsePrefs() {
29 ClearPref(metrics::prefs::kUserCellDataUse);
30 ClearPref(metrics::prefs::kUmaCellDataUse);
31 }
32 };
33
34 void SetPrefTestValuesOverRatio(PrefService* local_state) {
35 base::DictionaryValue user_pref_dict;
36 user_pref_dict.SetInteger(kTodayStr, 2 * 100);
37 user_pref_dict.SetInteger(kYesterdayStr, 2 * 100);
38 user_pref_dict.SetInteger(kExpiredDateStr1, 2 * 100);
39 user_pref_dict.SetInteger(kExpiredDateStr2, 2 * 100);
40 local_state->Set(prefs::kUserCellDataUse, user_pref_dict);
41
42 base::DictionaryValue uma_pref_dict;
43 uma_pref_dict.SetInteger(kTodayStr, 50);
44 uma_pref_dict.SetInteger(kYesterdayStr, 50);
45 uma_pref_dict.SetInteger(kExpiredDateStr1, 50);
46 uma_pref_dict.SetInteger(kExpiredDateStr2, 50);
47 local_state->Set(prefs::kUmaCellDataUse, uma_pref_dict);
48 }
49
50 void SetPrefTestValuesValidRatio(PrefService* local_state) {
51 base::DictionaryValue user_pref_dict;
52 user_pref_dict.SetInteger(kTodayStr, 100 * 100);
53 user_pref_dict.SetInteger(kYesterdayStr, 100 * 100);
54 user_pref_dict.SetInteger(kExpiredDateStr1, 100 * 100);
55 user_pref_dict.SetInteger(kExpiredDateStr2, 100 * 100);
56 local_state->Set(prefs::kUserCellDataUse, user_pref_dict);
57
58 // Should be 4% of user traffic
59 base::DictionaryValue uma_pref_dict;
60 uma_pref_dict.SetInteger(kTodayStr, 4 * 100);
61 uma_pref_dict.SetInteger(kYesterdayStr, 4 * 100);
62 uma_pref_dict.SetInteger(kExpiredDateStr1, 4 * 100);
63 uma_pref_dict.SetInteger(kExpiredDateStr2, 4 * 100);
64 local_state->Set(prefs::kUmaCellDataUse, uma_pref_dict);
65 }
66
67 } // namespace
68
69 TEST(DataUseTrackerTest, CheckUpdateUsagePref) {
70 TestDataUsePrefService local_state;
71 DataUseTracker data_use_tracker(&local_state);
72 local_state.ClearDataUsePrefs();
73 data_use_tracker.SetMeasurementDateForTesting(kTodayStr);
74
75 int user_pref_value = 0;
76 int uma_pref_value = 0;
77
78 data_use_tracker.UpdateMetricsUsagePrefsOnUIThread("", 2 * 100);
79 local_state.GetDictionary(prefs::kUserCellDataUse)
80 ->GetInteger(kTodayStr, &user_pref_value);
81 EXPECT_EQ(2 * 100, user_pref_value);
82 local_state.GetDictionary(prefs::kUmaCellDataUse)
83 ->GetInteger(kTodayStr, &uma_pref_value);
84 EXPECT_EQ(0, uma_pref_value);
85
86 data_use_tracker.UpdateMetricsUsagePrefsOnUIThread("UMA", 100);
87 local_state.GetDictionary(prefs::kUserCellDataUse)
88 ->GetInteger(kTodayStr, &user_pref_value);
89 EXPECT_EQ(3 * 100, user_pref_value);
90 local_state.GetDictionary(prefs::kUmaCellDataUse)
91 ->GetInteger(kTodayStr, &uma_pref_value);
92 EXPECT_EQ(100, uma_pref_value);
93 }
94
95 TEST(DataUseTrackerTest, CheckRemoveExpiredEntries) {
96 TestDataUsePrefService local_state;
97 DataUseTracker data_use_tracker(&local_state);
98 local_state.ClearDataUsePrefs();
99 data_use_tracker.SetMeasurementDateForTesting(kTodayStr);
100 SetPrefTestValuesOverRatio(&local_state);
101 data_use_tracker.RemoveExpiredEntries();
102
103 int user_pref_value = 0;
104 int uma_pref_value = 0;
105
106 local_state.GetDictionary(prefs::kUserCellDataUse)
107 ->GetInteger(kExpiredDateStr1, &user_pref_value);
108 EXPECT_EQ(0, user_pref_value);
109 local_state.GetDictionary(prefs::kUmaCellDataUse)
110 ->GetInteger(kExpiredDateStr1, &uma_pref_value);
111 EXPECT_EQ(0, uma_pref_value);
112
113 local_state.GetDictionary(prefs::kUserCellDataUse)
114 ->GetInteger(kExpiredDateStr2, &user_pref_value);
115 EXPECT_EQ(0, user_pref_value);
116 local_state.GetDictionary(prefs::kUmaCellDataUse)
117 ->GetInteger(kExpiredDateStr2, &uma_pref_value);
118 EXPECT_EQ(0, uma_pref_value);
119
120 local_state.GetDictionary(prefs::kUserCellDataUse)
121 ->GetInteger(kTodayStr, &user_pref_value);
122 EXPECT_EQ(2 * 100, user_pref_value);
123 local_state.GetDictionary(prefs::kUmaCellDataUse)
124 ->GetInteger(kTodayStr, &uma_pref_value);
125 EXPECT_EQ(50, uma_pref_value);
126
127 local_state.GetDictionary(prefs::kUserCellDataUse)
128 ->GetInteger(kYesterdayStr, &user_pref_value);
129 EXPECT_EQ(2 * 100, user_pref_value);
130 local_state.GetDictionary(prefs::kUmaCellDataUse)
131 ->GetInteger(kYesterdayStr, &uma_pref_value);
132 EXPECT_EQ(50, uma_pref_value);
133 }
134
135 TEST(DataUseTrackerTest, CheckComputeTotalDataUse) {
136 TestDataUsePrefService local_state;
137 DataUseTracker data_use_tracker(&local_state);
138 local_state.ClearDataUsePrefs();
139 data_use_tracker.SetMeasurementDateForTesting(kTodayStr);
140 SetPrefTestValuesOverRatio(&local_state);
141
142 int user_data_use =
143 data_use_tracker.ComputeTotalDataUse(prefs::kUserCellDataUse);
144 EXPECT_EQ(8 * 100, user_data_use);
145 int uma_data_use =
146 data_use_tracker.ComputeTotalDataUse(prefs::kUmaCellDataUse);
147 EXPECT_EQ(4 * 50, uma_data_use);
148 }
149
150 TEST(DataUseTrackerTest, CheckCanUploadUMALog) {
151 TestDataUsePrefService local_state;
152 DataUseTracker data_use_tracker(&local_state);
153 data_use_tracker.SetMeasurementDateForTesting(kTodayStr);
154 data_use_tracker.SetUmaQoutaForTesting(200);
155 data_use_tracker.SetUmaRatioForTesting(0.05);
156 local_state.ClearDataUsePrefs();
157 SetPrefTestValuesOverRatio(&local_state);
158
159 bool can_upload = data_use_tracker.CanUploadUMALog(50);
160 EXPECT_TRUE(can_upload);
161 can_upload = data_use_tracker.CanUploadUMALog(100);
162 EXPECT_TRUE(can_upload);
163 can_upload = data_use_tracker.CanUploadUMALog(150);
164 EXPECT_FALSE(can_upload);
165
166 local_state.ClearDataUsePrefs();
167 SetPrefTestValuesValidRatio(&local_state);
168 can_upload = data_use_tracker.CanUploadUMALog(100);
169 EXPECT_TRUE(can_upload);
170 can_upload = data_use_tracker.CanUploadUMALog(200); // this is about 0.49%
171 EXPECT_TRUE(can_upload);
172 can_upload = data_use_tracker.CanUploadUMALog(300);
173 EXPECT_FALSE(can_upload);
174 }
175
176 } // namespace metrics
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698