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

Side by Side Diff: chrome/browser/extensions/api/feedback_private/log_source_access_manager_unittest.cc

Issue 2840103002: Add new API function: feedbackPrivate.readLogSource (Closed)
Patch Set: Addressed comments from Patch Set 4 Created 3 years, 6 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 2017 The Chromium Authors. All rights reserved.
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 "chrome/browser/extensions/api/feedback_private/log_source_access_manag er.h"
6
7 #include <string>
8 #include <utility>
9
10 #include "base/macros.h"
11 #include "testing/gtest/include/gtest/gtest.h"
12
13 namespace extensions {
14
15 namespace {
16
17 using extensions::api::feedback_private::LOG_SOURCE_MESSAGES;
18 using extensions::api::feedback_private::LOG_SOURCE_UI_LATEST;
19 using SourceAndExtension = LogSourceAccessManager::SourceAndExtension;
20
21 } // namespace
22
23 TEST(LogSourceAccessManagerTest, Empty) {
24 LogSourceAccessManager manager((base::TimeDelta()));
25
26 EXPECT_EQ(0U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
27 EXPECT_EQ(0U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_UI_LATEST));
28 EXPECT_TRUE(manager
29 .GetLastExtensionAccessTime(
30 SourceAndExtension(LOG_SOURCE_UI_LATEST, ""))
31 .is_null());
32 }
33
34 TEST(LogSourceAccessManagerTest, OneSourceOneExtension) {
35 LogSourceAccessManager manager((base::TimeDelta()));
36
37 const SourceAndExtension key(LOG_SOURCE_MESSAGES, "aaaa");
38
39 EXPECT_TRUE(manager.AddExtension(key));
40 EXPECT_EQ(1U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
41 EXPECT_FALSE(manager.AddExtension(key));
42 EXPECT_EQ(1U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
43
44 EXPECT_TRUE(manager.RemoveExtension(key));
45 EXPECT_EQ(0U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
46 EXPECT_FALSE(manager.RemoveExtension(key));
47 EXPECT_EQ(0U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
48 }
49
50 TEST(LogSourceAccessManagerTest, OneSourceMultipleExtensions) {
51 LogSourceAccessManager manager((base::TimeDelta()));
52
53 const SourceAndExtension key_a(LOG_SOURCE_MESSAGES, "aaaa");
54 const SourceAndExtension key_b(LOG_SOURCE_MESSAGES, "bbbb");
55 const SourceAndExtension key_c(LOG_SOURCE_MESSAGES, "cccc");
56 const SourceAndExtension key_d(LOG_SOURCE_MESSAGES, "dddd");
57
58 // Add extensions "aaaa", "bbbb", and "cccc".
59 EXPECT_TRUE(manager.AddExtension(key_a));
60 EXPECT_EQ(1U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
61 EXPECT_FALSE(manager.AddExtension(key_a));
62 EXPECT_EQ(1U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
63
64 EXPECT_TRUE(manager.AddExtension(key_b));
65 EXPECT_EQ(2U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
66 EXPECT_FALSE(manager.AddExtension(key_b));
67 EXPECT_EQ(2U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
68
69 EXPECT_TRUE(manager.AddExtension(key_c));
70 EXPECT_EQ(3U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
71 EXPECT_FALSE(manager.AddExtension(key_c));
72 EXPECT_EQ(3U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
73
74 // Remove extensions "bbbb" and "aaaa".
75 EXPECT_TRUE(manager.RemoveExtension(key_b));
76 EXPECT_EQ(2U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
77 EXPECT_FALSE(manager.RemoveExtension(key_b));
78 EXPECT_EQ(2U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
79
80 EXPECT_TRUE(manager.RemoveExtension(key_a));
81 EXPECT_EQ(1U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
82 EXPECT_FALSE(manager.RemoveExtension(key_a));
83 EXPECT_EQ(1U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
84
85 // Add extension "dddd".
86 EXPECT_TRUE(manager.AddExtension(key_d));
87 EXPECT_EQ(2U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
88 EXPECT_FALSE(manager.AddExtension(key_d));
89 EXPECT_EQ(2U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
90
91 // Remove extensions "cccc" and "dddd".
92 EXPECT_TRUE(manager.RemoveExtension(key_c));
93 EXPECT_EQ(1U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
94 EXPECT_FALSE(manager.RemoveExtension(key_c));
95 EXPECT_EQ(1U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
96
97 EXPECT_TRUE(manager.RemoveExtension(key_d));
98 EXPECT_EQ(0U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
99 EXPECT_FALSE(manager.RemoveExtension(key_d));
100 EXPECT_EQ(0U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
101 }
102
103 TEST(LogSourceAccessManagerTest, MultipleSourcesMultipleExtensions) {
104 LogSourceAccessManager manager((base::TimeDelta()));
105
106 const SourceAndExtension key_a0(LOG_SOURCE_MESSAGES, "aaaa");
107 const SourceAndExtension key_a1(LOG_SOURCE_UI_LATEST, "aaaa");
108 const SourceAndExtension key_b0(LOG_SOURCE_MESSAGES, "bbbb");
109 const SourceAndExtension key_b1(LOG_SOURCE_UI_LATEST, "bbbb");
110 const SourceAndExtension key_c0(LOG_SOURCE_MESSAGES, "cccc");
111 const SourceAndExtension key_c1(LOG_SOURCE_UI_LATEST, "cccc");
112
113 // Add the above entries.
114 EXPECT_TRUE(manager.AddExtension(key_a0));
115 EXPECT_EQ(1U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
116 EXPECT_EQ(0U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_UI_LATEST));
117 EXPECT_TRUE(manager.AddExtension(key_a1));
118 EXPECT_EQ(1U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
119 EXPECT_EQ(1U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_UI_LATEST));
120 EXPECT_FALSE(manager.AddExtension(key_a0));
121 EXPECT_FALSE(manager.AddExtension(key_a1));
122 EXPECT_EQ(1U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
123 EXPECT_EQ(1U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_UI_LATEST));
124
125 EXPECT_TRUE(manager.AddExtension(key_b0));
126 EXPECT_EQ(2U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
127 EXPECT_EQ(1U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_UI_LATEST));
128 EXPECT_TRUE(manager.AddExtension(key_b1));
129 EXPECT_EQ(2U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
130 EXPECT_EQ(2U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_UI_LATEST));
131 EXPECT_FALSE(manager.AddExtension(key_b0));
132 EXPECT_FALSE(manager.AddExtension(key_b1));
133 EXPECT_EQ(2U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
134 EXPECT_EQ(2U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_UI_LATEST));
135
136 EXPECT_TRUE(manager.AddExtension(key_c1));
137 EXPECT_EQ(2U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
138 EXPECT_EQ(3U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_UI_LATEST));
139 EXPECT_FALSE(manager.AddExtension(key_c1));
140 EXPECT_EQ(2U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
141 EXPECT_EQ(3U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_UI_LATEST));
142 EXPECT_TRUE(manager.AddExtension(key_c0));
143 EXPECT_FALSE(manager.AddExtension(key_c0));
144 EXPECT_FALSE(manager.AddExtension(key_c1));
145 EXPECT_EQ(3U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
146 EXPECT_EQ(3U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_UI_LATEST));
147
148 // Remove all the entries.
149 EXPECT_TRUE(manager.RemoveExtension(key_a0));
150 EXPECT_EQ(2U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
151 EXPECT_EQ(3U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_UI_LATEST));
152 EXPECT_FALSE(manager.RemoveExtension(key_a0));
153 EXPECT_EQ(2U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
154 EXPECT_EQ(3U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_UI_LATEST));
155
156 EXPECT_TRUE(manager.RemoveExtension(key_b0));
157 EXPECT_EQ(1U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
158 EXPECT_EQ(3U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_UI_LATEST));
159 EXPECT_FALSE(manager.RemoveExtension(key_b0));
160 EXPECT_EQ(1U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
161 EXPECT_EQ(3U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_UI_LATEST));
162
163 EXPECT_TRUE(manager.RemoveExtension(key_c0));
164 EXPECT_EQ(0U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
165 EXPECT_EQ(3U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_UI_LATEST));
166 EXPECT_FALSE(manager.RemoveExtension(key_c0));
167 EXPECT_EQ(0U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
168 EXPECT_EQ(3U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_UI_LATEST));
169
170 EXPECT_TRUE(manager.RemoveExtension(key_c1));
171 EXPECT_EQ(0U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
172 EXPECT_EQ(2U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_UI_LATEST));
173 EXPECT_FALSE(manager.RemoveExtension(key_c1));
174 EXPECT_EQ(0U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
175 EXPECT_EQ(2U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_UI_LATEST));
176
177 EXPECT_TRUE(manager.RemoveExtension(key_b1));
178 EXPECT_EQ(0U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
179 EXPECT_EQ(1U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_UI_LATEST));
180 EXPECT_FALSE(manager.RemoveExtension(key_b1));
181 EXPECT_EQ(0U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
182 EXPECT_EQ(1U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_UI_LATEST));
183
184 EXPECT_TRUE(manager.RemoveExtension(key_a1));
185 EXPECT_EQ(0U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
186 EXPECT_EQ(0U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_UI_LATEST));
187 EXPECT_FALSE(manager.RemoveExtension(key_a1));
188 EXPECT_EQ(0U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_MESSAGES));
189 EXPECT_EQ(0U, manager.GetNumActiveExtensionsForSource(LOG_SOURCE_UI_LATEST));
190 }
191
192 TEST(LogSourceAccessManagerTest, LastAccessTime) {
193 // Specify a long minimum duration between reads to avoid non-deterministic
194 // timing variations between tests. For practical purposes, this means we can
195 // only read from the source once during the lifetime of this test.
196 LogSourceAccessManager manager(base::TimeDelta::FromDays(30));
197
198 const SourceAndExtension key_a0(LOG_SOURCE_MESSAGES, "aaaa");
199 const SourceAndExtension key_a1(LOG_SOURCE_UI_LATEST, "aaaa");
200 const SourceAndExtension key_b0(LOG_SOURCE_MESSAGES, "bbbb");
201 const SourceAndExtension key_b1(LOG_SOURCE_UI_LATEST, "bbbb");
202 const SourceAndExtension key_c0(LOG_SOURCE_MESSAGES, "cccc");
203 const SourceAndExtension key_c1(LOG_SOURCE_UI_LATEST, "cccc");
204
205 // No timestamps present for any of the keys.
206 EXPECT_TRUE(manager.GetLastExtensionAccessTime(key_a0).is_null());
207 EXPECT_TRUE(manager.GetLastExtensionAccessTime(key_a1).is_null());
208 EXPECT_TRUE(manager.GetLastExtensionAccessTime(key_b0).is_null());
209 EXPECT_TRUE(manager.GetLastExtensionAccessTime(key_b1).is_null());
210 EXPECT_TRUE(manager.GetLastExtensionAccessTime(key_c0).is_null());
211 EXPECT_TRUE(manager.GetLastExtensionAccessTime(key_c1).is_null());
212
213 // Access each key for the first time.
214 EXPECT_TRUE(manager.AccessSourceFromExtension(key_a0));
215 EXPECT_TRUE(manager.AccessSourceFromExtension(key_b0));
216 EXPECT_TRUE(manager.AccessSourceFromExtension(key_c0));
217 EXPECT_TRUE(manager.AccessSourceFromExtension(key_a1));
218 EXPECT_TRUE(manager.AccessSourceFromExtension(key_b1));
219 EXPECT_TRUE(manager.AccessSourceFromExtension(key_c1));
220
221 // Each key should now have a last access timestamp.
222 EXPECT_FALSE(manager.GetLastExtensionAccessTime(key_a0).is_null());
223 EXPECT_FALSE(manager.GetLastExtensionAccessTime(key_a1).is_null());
224 EXPECT_FALSE(manager.GetLastExtensionAccessTime(key_b0).is_null());
225 EXPECT_FALSE(manager.GetLastExtensionAccessTime(key_b1).is_null());
226 EXPECT_FALSE(manager.GetLastExtensionAccessTime(key_c0).is_null());
227 EXPECT_FALSE(manager.GetLastExtensionAccessTime(key_c1).is_null());
228
229 // Cannot access them again.
230 EXPECT_FALSE(manager.AccessSourceFromExtension(key_a0));
231 EXPECT_FALSE(manager.AccessSourceFromExtension(key_b0));
232 EXPECT_FALSE(manager.AccessSourceFromExtension(key_c0));
233 EXPECT_FALSE(manager.AccessSourceFromExtension(key_a1));
234 EXPECT_FALSE(manager.AccessSourceFromExtension(key_b1));
235 EXPECT_FALSE(manager.AccessSourceFromExtension(key_c1));
236 }
237
238 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698