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

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

Issue 2733393003: Split browsing data masks between content and embedder (Closed)
Patch Set: Rebase (merged automatically) 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 182 matching lines...) Expand 10 before | Expand all | Expand 10 after
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(base::Time(), base::Time::Max(), remove_mask,
239 BrowsingDataHelper::UNPROTECTED_WEB, &observer); 240 BrowsingDataRemover::ORIGIN_TYPE_UNPROTECTED_WEB,
241 &observer);
240 observer.BlockUntilCompletion(); 242 observer.BlockUntilCompletion();
241 // BrowsingDataRemover deletes itself. 243 // BrowsingDataRemover deletes itself.
242 } 244 }
243 245
244 // Returns true if the prerender is expected to abort on its own, before 246 // Returns true if the prerender is expected to abort on its own, before
245 // attempting to swap it. 247 // attempting to swap it.
246 bool ShouldAbortPrerenderBeforeSwap(FinalStatus status) { 248 bool ShouldAbortPrerenderBeforeSwap(FinalStatus status) {
247 switch (status) { 249 switch (status) {
248 case FINAL_STATUS_USED: 250 case FINAL_STATUS_USED:
249 case FINAL_STATUS_WINDOW_OPENER: 251 case FINAL_STATUS_WINDOW_OPENER:
(...skipping 2267 matching lines...) Expand 10 before | Expand all | Expand 10 after
2517 } 2519 }
2518 2520
2519 2521
2520 // Checks that when the history is cleared, prerendering is cancelled and 2522 // Checks that when the history is cleared, prerendering is cancelled and
2521 // prerendering history is cleared. 2523 // prerendering history is cleared.
2522 IN_PROC_BROWSER_TEST_F(PrerenderBrowserTest, PrerenderClearHistory) { 2524 IN_PROC_BROWSER_TEST_F(PrerenderBrowserTest, PrerenderClearHistory) {
2523 std::unique_ptr<TestPrerender> prerender = 2525 std::unique_ptr<TestPrerender> prerender =
2524 PrerenderTestURL("/prerender/prerender_page.html", 2526 PrerenderTestURL("/prerender/prerender_page.html",
2525 FINAL_STATUS_CACHE_OR_HISTORY_CLEARED, 1); 2527 FINAL_STATUS_CACHE_OR_HISTORY_CLEARED, 1);
2526 2528
2527 ClearBrowsingData(current_browser(), BrowsingDataRemover::REMOVE_HISTORY); 2529 ClearBrowsingData(current_browser(),
2530 ChromeBrowsingDataRemoverDelegate::DATA_TYPE_HISTORY);
2528 prerender->WaitForStop(); 2531 prerender->WaitForStop();
2529 2532
2530 // Make sure prerender history was cleared. 2533 // Make sure prerender history was cleared.
2531 EXPECT_EQ(0U, GetHistoryLength()); 2534 EXPECT_EQ(0U, GetHistoryLength());
2532 } 2535 }
2533 2536
2534 // Checks that when the cache is cleared, prerenders are cancelled but 2537 // Checks that when the cache is cleared, prerenders are cancelled but
2535 // prerendering history is not cleared. 2538 // prerendering history is not cleared.
2536 IN_PROC_BROWSER_TEST_F(PrerenderBrowserTest, PrerenderClearCache) { 2539 IN_PROC_BROWSER_TEST_F(PrerenderBrowserTest, PrerenderClearCache) {
2537 std::unique_ptr<TestPrerender> prerender = 2540 std::unique_ptr<TestPrerender> prerender =
2538 PrerenderTestURL("/prerender/prerender_page.html", 2541 PrerenderTestURL("/prerender/prerender_page.html",
2539 FINAL_STATUS_CACHE_OR_HISTORY_CLEARED, 1); 2542 FINAL_STATUS_CACHE_OR_HISTORY_CLEARED, 1);
2540 2543
2541 ClearBrowsingData(current_browser(), BrowsingDataRemover::REMOVE_CACHE); 2544 ClearBrowsingData(current_browser(), BrowsingDataRemover::DATA_TYPE_CACHE);
2542 prerender->WaitForStop(); 2545 prerender->WaitForStop();
2543 2546
2544 // Make sure prerender history was not cleared. Not a vital behavior, but 2547 // Make sure prerender history was not cleared. Not a vital behavior, but
2545 // used to compare with PrerenderClearHistory test. 2548 // used to compare with PrerenderClearHistory test.
2546 EXPECT_EQ(1U, GetHistoryLength()); 2549 EXPECT_EQ(1U, GetHistoryLength());
2547 } 2550 }
2548 2551
2549 IN_PROC_BROWSER_TEST_F(PrerenderBrowserTest, PrerenderCancelAll) { 2552 IN_PROC_BROWSER_TEST_F(PrerenderBrowserTest, PrerenderCancelAll) {
2550 std::unique_ptr<TestPrerender> prerender = PrerenderTestURL( 2553 std::unique_ptr<TestPrerender> prerender = PrerenderTestURL(
2551 "/prerender/prerender_page.html", FINAL_STATUS_CANCELLED, 1); 2554 "/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(); 3814 browser()->tab_strip_model()->GetActiveWebContents();
3812 bool display_test_result = false; 3815 bool display_test_result = false;
3813 ASSERT_TRUE(content::ExecuteScriptAndExtractBool(web_contents, 3816 ASSERT_TRUE(content::ExecuteScriptAndExtractBool(web_contents,
3814 "DidDisplayReallyPass()", 3817 "DidDisplayReallyPass()",
3815 &display_test_result)); 3818 &display_test_result));
3816 ASSERT_TRUE(display_test_result); 3819 ASSERT_TRUE(display_test_result);
3817 } 3820 }
3818 #endif // !defined(DISABLE_NACL) 3821 #endif // !defined(DISABLE_NACL)
3819 3822
3820 } // namespace prerender 3823 } // namespace prerender
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698