Extensions cleanup: Merge IsSyncableApp+Extension, ShouldSyncApp+Extension
[chromium-blink-merge.git] / chrome / browser / extensions / activity_log / uma_policy_browsertest.cc
blob3110310583bceca493c61b7254c07091de82bfda
1 // Copyright 2013 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.
5 #include "base/metrics/histogram.h"
6 #include "base/strings/stringprintf.h"
7 #include "chrome/browser/extensions/activity_log/uma_policy.h"
8 #include "chrome/browser/extensions/extension_apitest.h"
9 #include "chrome/browser/extensions/extension_browsertest.h"
10 #include "chrome/browser/extensions/extension_service.h"
11 #include "chrome/browser/extensions/test_extension_dir.h"
12 #include "chrome/browser/ui/browser_window.h"
13 #include "chrome/test/base/ui_test_utils.h"
14 #include "extensions/common/manifest_constants.h"
15 #include "net/dns/mock_host_resolver.h"
17 using extensions::UmaPolicy;
19 const char kGooglePrefix[] = "ExtensionActivity.Google";
20 const char kNonGooglePrefix[] = "ExtensionActivity";
22 // These tests need to ensure that all of the extension JavaScript completes
23 // before the histograms are checked. To accomplish this, the test relies on
24 // some JavaScript in chrome/test/data/extensions/api_test/uma_policy/:
25 // * When the test navigates to opener.com, opener.js will use window.open() to
26 // pop open a new window with the appropriate URL for the test case. This
27 // ensures that the testing framework never reuses a window that's still
28 // running a previous test case.
29 // * The test extension code in content_script.js tells background.js when it's
30 // done. When it's finished, background.js closes the blocker.com window. So
31 // blocker.com will remain open (and block) until the tests complete.
32 class ActivityLogUmaPolicyTest : public ExtensionApiTest {
35 std::string ConcatNames(const char* prefix, int status_num) {
36 return base::StringPrintf(
37 "%s.%s",
38 prefix,
39 extensions::UmaPolicy::GetHistogramName(
40 static_cast<extensions::UmaPolicy::PageStatus>(status_num)));
43 // TODO(felt): These are disabled due to crbug.com/294500, since they fail
44 // due to a blink bug. The fix went in to Blink on Thursday and should roll
45 // on Monday 9/23.
46 // These are all sequential navigations, so they should each be logged
47 // independently.
48 IN_PROC_BROWSER_TEST_F(ActivityLogUmaPolicyTest, DISABLED_SequentialNavs) {
49 host_resolver()->AddRule("*", "127.0.0.1");
50 StartEmbeddedTestServer();
52 const extensions::Extension* ext =
53 LoadExtension(test_data_dir_.AppendASCII("uma_policy"));
54 ASSERT_TRUE(ext);
56 ui_test_utils::NavigateToURLWithDisposition(
57 browser(), GURL("http://www.opener.com/#google"), NEW_WINDOW,
58 ui_test_utils::BROWSER_TEST_NONE);
59 ui_test_utils::NavigateToURLBlockUntilNavigationsComplete(
60 browser(), GURL("http://www.blocker.com"), 2);
61 ui_test_utils::NavigateToURLWithDisposition(
62 browser(), GURL("http://www.opener.com/#google?q=a"), NEW_WINDOW,
63 ui_test_utils::BROWSER_TEST_NONE);
64 ui_test_utils::NavigateToURLBlockUntilNavigationsComplete(
65 browser(), GURL("http://www.blocker.com"), 2);
66 ui_test_utils::NavigateToURLWithDisposition(
67 browser(), GURL("http://www.opener.com/#google?q=b"), NEW_WINDOW,
68 ui_test_utils::BROWSER_TEST_NONE);
69 ui_test_utils::NavigateToURLBlockUntilNavigationsComplete(
70 browser(), GURL("http://www.blocker.com"), 2);
71 ui_test_utils::NavigateToURLWithDisposition(
72 browser(), GURL("http://www.opener.com/#cnn?q=a"), NEW_WINDOW,
73 ui_test_utils::BROWSER_TEST_NONE);
74 ui_test_utils::NavigateToURLBlockUntilNavigationsComplete(
75 browser(), GURL("http://www.blocker.com"), 2);
76 ui_test_utils::NavigateToURLWithDisposition(
77 browser(), GURL("http://www.opener.com/#cnn?q=b"), NEW_WINDOW,
78 ui_test_utils::BROWSER_TEST_NONE);
79 ui_test_utils::NavigateToURLBlockUntilNavigationsComplete(
80 browser(), GURL("http://www.blocker.com"), 2);
82 for (int i = UmaPolicy::NONE + 1; i < UmaPolicy::MAX_STATUS - 2; ++i) {
83 base::HistogramBase* google_histogram = base::Histogram::FactoryGet(
84 ConcatNames(kGooglePrefix, i),
85 1, 100, 50, base::HistogramBase::kNoFlags);
86 scoped_ptr<base::HistogramSamples> google_samples =
87 google_histogram->SnapshotSamples();
88 EXPECT_EQ(3, google_samples->TotalCount());
89 EXPECT_EQ(3, google_samples->GetCount(1));
91 base::HistogramBase* cnn_histogram = base::Histogram::FactoryGet(
92 ConcatNames(kNonGooglePrefix, i),
93 1, 100, 50, base::HistogramBase::kNoFlags);
94 scoped_ptr<base::HistogramSamples> cnn_samples =
95 cnn_histogram->SnapshotSamples();
96 if (ConcatNames(kNonGooglePrefix, i) != "ExtensionActivity.ContentScript" &&
97 ConcatNames(kNonGooglePrefix, i) != "ExtensionActivity.ReadDom") {
98 // There's a content script on opener.com that checks the location.
99 // The test is not set up to accurately record opener.com histograms due
100 // to the possibility of race conditions in the testing framework, so we
101 // can't check those values.
102 EXPECT_EQ(2, cnn_samples->GetCount(1));
107 // Two windows are open at once with the same google.com TLD.
108 // However, they should be treated separately because they have different URLs.
109 IN_PROC_BROWSER_TEST_F(
110 ActivityLogUmaPolicyTest, DISABLED_ParallelDistinctNavs) {
111 host_resolver()->AddRule("*", "127.0.0.1");
112 StartEmbeddedTestServer();
114 const extensions::Extension* ext =
115 LoadExtension(test_data_dir_.AppendASCII("uma_policy"));
116 ASSERT_TRUE(ext);
118 ui_test_utils::NavigateToURLWithDisposition(
119 browser(), GURL("http://www.opener.com/#google?p=a"), NEW_WINDOW,
120 ui_test_utils::BROWSER_TEST_NONE);
121 ui_test_utils::NavigateToURLWithDisposition(
122 browser(), GURL("http://www.opener.com/#google?p=b"), NEW_WINDOW,
123 ui_test_utils::BROWSER_TEST_NONE);
124 ui_test_utils::NavigateToURLBlockUntilNavigationsComplete(
125 browser(), GURL("http://www.blocker.com"), 2);
127 for (int i = UmaPolicy::NONE + 1; i < UmaPolicy::MAX_STATUS - 2; ++i) {
128 base::HistogramBase* google_histogram = base::Histogram::FactoryGet(
129 ConcatNames(kGooglePrefix, i),
130 1, 100, 50, base::HistogramBase::kNoFlags);
131 scoped_ptr<base::HistogramSamples> google_samples =
132 google_histogram->SnapshotSamples();
133 EXPECT_EQ(2, google_samples->GetCount(1));
137 // Two windows are open at once with the same Google URLs.
138 // They should be treated the same.
139 IN_PROC_BROWSER_TEST_F(ActivityLogUmaPolicyTest, DISABLED_Google_ParallelSame) {
140 host_resolver()->AddRule("*", "127.0.0.1");
141 StartEmbeddedTestServer();
143 const extensions::Extension* ext =
144 LoadExtension(test_data_dir_.AppendASCII("uma_policy"));
145 ASSERT_TRUE(ext);
147 ui_test_utils::NavigateToURLWithDisposition(
148 browser(), GURL("http://www.opener.com/#googlea"), NEW_WINDOW,
149 ui_test_utils::BROWSER_TEST_NONE);
150 ui_test_utils::NavigateToURLWithDisposition(
151 browser(), GURL("http://www.opener.com/#googleb"), NEW_WINDOW,
152 ui_test_utils::BROWSER_TEST_NONE);
153 ui_test_utils::NavigateToURLBlockUntilNavigationsComplete(
154 browser(), GURL("http://www.blocker.com"), 2);
156 for (int i = UmaPolicy::NONE + 1; i < UmaPolicy::MAX_STATUS - 2; ++i) {
157 base::HistogramBase* google_histogram = base::Histogram::FactoryGet(
158 ConcatNames(kGooglePrefix, i),
159 1, 100, 50, base::HistogramBase::kNoFlags);
160 scoped_ptr<base::HistogramSamples> google_samples =
161 google_histogram->SnapshotSamples();
162 EXPECT_EQ(1, google_samples->GetCount(1));
166 // Two windows are open at once with the same non-Google URLs.
167 // They should be treated the same.
168 IN_PROC_BROWSER_TEST_F(ActivityLogUmaPolicyTest,
169 DISABLED_NonGoogle_ParallelSame) {
170 host_resolver()->AddRule("*", "127.0.0.1");
171 StartEmbeddedTestServer();
173 const extensions::Extension* ext =
174 LoadExtension(test_data_dir_.AppendASCII("uma_policy"));
175 ASSERT_TRUE(ext);
177 ui_test_utils::NavigateToURLWithDisposition(
178 browser(), GURL("http://www.opener.com/#cnna"), NEW_WINDOW,
179 ui_test_utils::BROWSER_TEST_NONE);
180 ui_test_utils::NavigateToURLWithDisposition(
181 browser(), GURL("http://www.opener.com/#cnnb"), NEW_WINDOW,
182 ui_test_utils::BROWSER_TEST_NONE);
183 ui_test_utils::NavigateToURLBlockUntilNavigationsComplete(
184 browser(), GURL("http://www.blocker.com"), 2);
186 for (int i = UmaPolicy::NONE + 1; i < UmaPolicy::MAX_STATUS - 2; ++i) {
187 base::HistogramBase* cnn_histogram = base::Histogram::FactoryGet(
188 ConcatNames(kNonGooglePrefix, i),
189 1, 100, 50, base::HistogramBase::kNoFlags);
190 scoped_ptr<base::HistogramSamples> cnn_samples =
191 cnn_histogram->SnapshotSamples();
192 if (ConcatNames(kNonGooglePrefix, i) != "ExtensionActivity.ContentScript" &&
193 ConcatNames(kNonGooglePrefix, i) != "ExtensionActivity.ReadDom") {
194 // There's a content script on opener.com that checks the location.
195 // The test is not set up to accurately record opener.com histograms due
196 // to the possibility of race conditions in the testing framework, so we
197 // can't check those values.
198 EXPECT_EQ(1, cnn_samples->GetCount(1));
203 // This runs with multiple extensions installed.
204 IN_PROC_BROWSER_TEST_F(ActivityLogUmaPolicyTest, DISABLED_MultipleExtensions) {
205 host_resolver()->AddRule("*", "127.0.0.1");
206 StartEmbeddedTestServer();
208 const extensions::Extension* ext =
209 LoadExtension(test_data_dir_.AppendASCII("uma_policy"));
210 ASSERT_TRUE(ext);
212 const char script2[] =
213 "document.createElement('script');"
214 "document.createElement('iframe');"
215 "document.createElement('div');"
216 "document.createElement('embed');"
217 "document.createElement('object');";
219 const char manifest[] =
221 " \"name\": \"Activity Log UMA Policy Test Extension\","
222 " \"version\": \"0.%s\","
223 " \"description\": \"Testing the histogramming\","
224 " \"content_scripts\": ["
225 " {"
226 " \"matches\": "
227 " [\"http://www.google.com/*\","
228 " \"http://www.cnn.com/*\"],"
229 " \"js\": [\"content_script.js\"]"
230 " }"
231 " ],"
232 " \"manifest_version\": 2"
233 "}";
235 extensions::TestExtensionDir dir2;
236 dir2.WriteManifest(base::StringPrintf(manifest, "2"));
237 dir2.WriteFile(FILE_PATH_LITERAL("content_script.js"), script2);
238 LoadExtension(dir2.unpacked_path());
240 ui_test_utils::NavigateToURLWithDisposition(
241 browser(), GURL("http://www.opener.com/#google"), NEW_WINDOW,
242 ui_test_utils::BROWSER_TEST_NONE);
243 ui_test_utils::NavigateToURLBlockUntilNavigationsComplete(
244 browser(), GURL("http://www.blocker.com"), 2);
245 ui_test_utils::NavigateToURLWithDisposition(
246 browser(), GURL("http://www.opener.com/#cnn?q=b"), NEW_WINDOW,
247 ui_test_utils::BROWSER_TEST_NONE);
248 ui_test_utils::NavigateToURLBlockUntilNavigationsComplete(
249 browser(), GURL("http://www.blocker.com"), 2);
251 const char* const subset_one[] = {
252 "CreatedLink",
253 "InnerHtml",
254 "DocumentWrite"
257 const char* const subset_two[] = {
258 "ContentScript",
259 "CreatedScript",
260 "CreatedIframe",
261 "CreatedDiv",
262 "CreatedEmbed",
263 "CreatedObject",
264 "InvokedDomMethod"
267 // These were only touched by one of the scripts.
268 for (size_t i = 0; i < arraysize(subset_one); ++i) {
269 base::HistogramBase* google_histogram = base::Histogram::FactoryGet(
270 std::string(kGooglePrefix) + "." + std::string(subset_one[i]),
271 1, 100, 50, base::HistogramBase::kNoFlags);
272 scoped_ptr<base::HistogramSamples> google_samples =
273 google_histogram->SnapshotSamples();
274 EXPECT_EQ(1, google_samples->GetCount(1));
276 base::HistogramBase* cnn_histogram = base::Histogram::FactoryGet(
277 std::string(kNonGooglePrefix) + "." + std::string(subset_one[i]),
278 1, 100, 50, base::HistogramBase::kNoFlags);
279 scoped_ptr<base::HistogramSamples> cnn_samples =
280 cnn_histogram->SnapshotSamples();
281 EXPECT_EQ(1, cnn_samples->GetCount(1));
284 // These were touched by both scripts.
285 for (size_t i = 0; i < arraysize(subset_two); ++i) {
286 base::HistogramBase* google_histogram = base::Histogram::FactoryGet(
287 std::string(kGooglePrefix) + "." + std::string(subset_two[i]),
288 1, 100, 50, base::HistogramBase::kNoFlags);
289 scoped_ptr<base::HistogramSamples> google_samples =
290 google_histogram->SnapshotSamples();
291 EXPECT_EQ(1, google_samples->GetCount(2));
293 base::HistogramBase* cnn_histogram = base::Histogram::FactoryGet(
294 std::string(kNonGooglePrefix) + "." + std::string(subset_two[i]),
295 1, 100, 50, base::HistogramBase::kNoFlags);
296 scoped_ptr<base::HistogramSamples> cnn_samples =
297 cnn_histogram->SnapshotSamples();
298 EXPECT_EQ(1, cnn_samples->GetCount(2));