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

Side by Side Diff: chrome/browser/prerender/prerender_browsertest.cc

Issue 2733393003: Split browsing data masks between content and embedder (Closed)
Patch Set: Extensions can't match extensions if there are no extensions. Created 3 years, 9 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 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include <stddef.h> 5 #include <stddef.h>
6 #include <deque> 6 #include <deque>
7 #include <set> 7 #include <set>
8 #include <string> 8 #include <string>
9 #include <unordered_map> 9 #include <unordered_map>
10 #include <utility> 10 #include <utility>
(...skipping 16 matching lines...) Expand all
27 #include "base/strings/utf_string_conversions.h" 27 #include "base/strings/utf_string_conversions.h"
28 #include "base/test/scoped_feature_list.h" 28 #include "base/test/scoped_feature_list.h"
29 #include "base/test/simple_test_tick_clock.h" 29 #include "base/test/simple_test_tick_clock.h"
30 #include "base/test/test_timeouts.h" 30 #include "base/test/test_timeouts.h"
31 #include "base/values.h" 31 #include "base/values.h"
32 #include "build/build_config.h" 32 #include "build/build_config.h"
33 #include "chrome/browser/browsing_data/browsing_data_helper.h" 33 #include "chrome/browser/browsing_data/browsing_data_helper.h"
34 #include "chrome/browser/browsing_data/browsing_data_remover.h" 34 #include "chrome/browser/browsing_data/browsing_data_remover.h"
35 #include "chrome/browser/browsing_data/browsing_data_remover_factory.h" 35 #include "chrome/browser/browsing_data/browsing_data_remover_factory.h"
36 #include "chrome/browser/browsing_data/browsing_data_remover_test_util.h" 36 #include "chrome/browser/browsing_data/browsing_data_remover_test_util.h"
37 #include "chrome/browser/browsing_data/chrome_browsing_data_remover_delegate.h"
37 #include "chrome/browser/chrome_content_browser_client.h" 38 #include "chrome/browser/chrome_content_browser_client.h"
38 #include "chrome/browser/chrome_notification_types.h" 39 #include "chrome/browser/chrome_notification_types.h"
39 #include "chrome/browser/content_settings/host_content_settings_map_factory.h" 40 #include "chrome/browser/content_settings/host_content_settings_map_factory.h"
40 #include "chrome/browser/extensions/api/web_navigation/web_navigation_api.h" 41 #include "chrome/browser/extensions/api/web_navigation/web_navigation_api.h"
41 #include "chrome/browser/extensions/extension_apitest.h" 42 #include "chrome/browser/extensions/extension_apitest.h"
42 #include "chrome/browser/external_protocol/external_protocol_handler.h" 43 #include "chrome/browser/external_protocol/external_protocol_handler.h"
43 #include "chrome/browser/net/prediction_options.h" 44 #include "chrome/browser/net/prediction_options.h"
44 #include "chrome/browser/page_load_metrics/observers/page_load_metrics_observer_ test_harness.h" 45 #include "chrome/browser/page_load_metrics/observers/page_load_metrics_observer_ test_harness.h"
45 #include "chrome/browser/page_load_metrics/observers/prerender_page_load_metrics _observer.h" 46 #include "chrome/browser/page_load_metrics/observers/prerender_page_load_metrics _observer.h"
46 #include "chrome/browser/password_manager/password_store_factory.h" 47 #include "chrome/browser/password_manager/password_store_factory.h"
(...skipping 181 matching lines...) Expand 10 before | Expand all | Expand 10 after
228 std::string CreateServerRedirect(const std::string& dest_url) { 229 std::string CreateServerRedirect(const std::string& dest_url) {
229 const char* const kServerRedirectBase = "/server-redirect?"; 230 const char* const kServerRedirectBase = "/server-redirect?";
230 return kServerRedirectBase + net::EscapeQueryParamValue(dest_url, false); 231 return kServerRedirectBase + net::EscapeQueryParamValue(dest_url, false);
231 } 232 }
232 233
233 // Clears the specified data using BrowsingDataRemover. 234 // Clears the specified data using BrowsingDataRemover.
234 void ClearBrowsingData(Browser* browser, int remove_mask) { 235 void ClearBrowsingData(Browser* browser, int remove_mask) {
235 BrowsingDataRemover* remover = 236 BrowsingDataRemover* remover =
236 BrowsingDataRemoverFactory::GetForBrowserContext(browser->profile()); 237 BrowsingDataRemoverFactory::GetForBrowserContext(browser->profile());
237 BrowsingDataRemoverCompletionObserver observer(remover); 238 BrowsingDataRemoverCompletionObserver observer(remover);
238 remover->RemoveAndReply(base::Time(), base::Time::Max(), remove_mask, 239 remover->RemoveAndReply(
239 BrowsingDataHelper::UNPROTECTED_WEB, &observer); 240 base::Time(), base::Time::Max(), remove_mask,
241 ChromeBrowsingDataRemoverDelegate::ORIGIN_TYPE_UNPROTECTED_WEB,
242 &observer);
240 observer.BlockUntilCompletion(); 243 observer.BlockUntilCompletion();
241 // BrowsingDataRemover deletes itself. 244 // BrowsingDataRemover deletes itself.
242 } 245 }
243 246
244 // Returns true if the prerender is expected to abort on its own, before 247 // Returns true if the prerender is expected to abort on its own, before
245 // attempting to swap it. 248 // attempting to swap it.
246 bool ShouldAbortPrerenderBeforeSwap(FinalStatus status) { 249 bool ShouldAbortPrerenderBeforeSwap(FinalStatus status) {
247 switch (status) { 250 switch (status) {
248 case FINAL_STATUS_USED: 251 case FINAL_STATUS_USED:
249 case FINAL_STATUS_WINDOW_OPENER: 252 case FINAL_STATUS_WINDOW_OPENER:
(...skipping 2267 matching lines...) Expand 10 before | Expand all | Expand 10 after
2517 } 2520 }
2518 2521
2519 2522
2520 // Checks that when the history is cleared, prerendering is cancelled and 2523 // Checks that when the history is cleared, prerendering is cancelled and
2521 // prerendering history is cleared. 2524 // prerendering history is cleared.
2522 IN_PROC_BROWSER_TEST_F(PrerenderBrowserTest, PrerenderClearHistory) { 2525 IN_PROC_BROWSER_TEST_F(PrerenderBrowserTest, PrerenderClearHistory) {
2523 std::unique_ptr<TestPrerender> prerender = 2526 std::unique_ptr<TestPrerender> prerender =
2524 PrerenderTestURL("/prerender/prerender_page.html", 2527 PrerenderTestURL("/prerender/prerender_page.html",
2525 FINAL_STATUS_CACHE_OR_HISTORY_CLEARED, 1); 2528 FINAL_STATUS_CACHE_OR_HISTORY_CLEARED, 1);
2526 2529
2527 ClearBrowsingData(current_browser(), BrowsingDataRemover::REMOVE_HISTORY); 2530 ClearBrowsingData(current_browser(),
2531 ChromeBrowsingDataRemoverDelegate::DATA_TYPE_HISTORY);
2528 prerender->WaitForStop(); 2532 prerender->WaitForStop();
2529 2533
2530 // Make sure prerender history was cleared. 2534 // Make sure prerender history was cleared.
2531 EXPECT_EQ(0U, GetHistoryLength()); 2535 EXPECT_EQ(0U, GetHistoryLength());
2532 } 2536 }
2533 2537
2534 // Checks that when the cache is cleared, prerenders are cancelled but 2538 // Checks that when the cache is cleared, prerenders are cancelled but
2535 // prerendering history is not cleared. 2539 // prerendering history is not cleared.
2536 IN_PROC_BROWSER_TEST_F(PrerenderBrowserTest, PrerenderClearCache) { 2540 IN_PROC_BROWSER_TEST_F(PrerenderBrowserTest, PrerenderClearCache) {
2537 std::unique_ptr<TestPrerender> prerender = 2541 std::unique_ptr<TestPrerender> prerender =
2538 PrerenderTestURL("/prerender/prerender_page.html", 2542 PrerenderTestURL("/prerender/prerender_page.html",
2539 FINAL_STATUS_CACHE_OR_HISTORY_CLEARED, 1); 2543 FINAL_STATUS_CACHE_OR_HISTORY_CLEARED, 1);
2540 2544
2541 ClearBrowsingData(current_browser(), BrowsingDataRemover::REMOVE_CACHE); 2545 ClearBrowsingData(current_browser(),
2546 ChromeBrowsingDataRemoverDelegate::DATA_TYPE_CACHE);
2542 prerender->WaitForStop(); 2547 prerender->WaitForStop();
2543 2548
2544 // Make sure prerender history was not cleared. Not a vital behavior, but 2549 // Make sure prerender history was not cleared. Not a vital behavior, but
2545 // used to compare with PrerenderClearHistory test. 2550 // used to compare with PrerenderClearHistory test.
2546 EXPECT_EQ(1U, GetHistoryLength()); 2551 EXPECT_EQ(1U, GetHistoryLength());
2547 } 2552 }
2548 2553
2549 IN_PROC_BROWSER_TEST_F(PrerenderBrowserTest, PrerenderCancelAll) { 2554 IN_PROC_BROWSER_TEST_F(PrerenderBrowserTest, PrerenderCancelAll) {
2550 std::unique_ptr<TestPrerender> prerender = PrerenderTestURL( 2555 std::unique_ptr<TestPrerender> prerender = PrerenderTestURL(
2551 "/prerender/prerender_page.html", FINAL_STATUS_CANCELLED, 1); 2556 "/prerender/prerender_page.html", FINAL_STATUS_CANCELLED, 1);
(...skipping 1259 matching lines...) Expand 10 before | Expand all | Expand 10 after
3811 browser()->tab_strip_model()->GetActiveWebContents(); 3816 browser()->tab_strip_model()->GetActiveWebContents();
3812 bool display_test_result = false; 3817 bool display_test_result = false;
3813 ASSERT_TRUE(content::ExecuteScriptAndExtractBool(web_contents, 3818 ASSERT_TRUE(content::ExecuteScriptAndExtractBool(web_contents,
3814 "DidDisplayReallyPass()", 3819 "DidDisplayReallyPass()",
3815 &display_test_result)); 3820 &display_test_result));
3816 ASSERT_TRUE(display_test_result); 3821 ASSERT_TRUE(display_test_result);
3817 } 3822 }
3818 #endif // !defined(DISABLE_NACL) 3823 #endif // !defined(DISABLE_NACL)
3819 3824
3820 } // namespace prerender 3825 } // namespace prerender
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698