Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 "base/command_line.h" | 5 #include "base/command_line.h" |
| 6 #include "base/strings/string16.h" | 6 #include "base/strings/string16.h" |
| 7 #include "base/strings/string_split.h" | 7 #include "base/strings/string_split.h" |
| 8 #include "base/task_scheduler/post_task.h" | 8 #include "base/task_scheduler/post_task.h" |
| 9 #include "chrome/browser/history/history_service_factory.h" | 9 #include "chrome/browser/history/history_service_factory.h" |
| 10 #include "chrome/browser/history/history_test_utils.h" | 10 #include "chrome/browser/history/history_test_utils.h" |
| 11 #include "chrome/browser/prerender/prerender_handle.h" | 11 #include "chrome/browser/prerender/prerender_handle.h" |
| 12 #include "chrome/browser/prerender/prerender_manager.h" | 12 #include "chrome/browser/prerender/prerender_manager.h" |
| 13 #include "chrome/browser/prerender/prerender_manager_factory.h" | 13 #include "chrome/browser/prerender/prerender_manager_factory.h" |
| 14 #include "chrome/browser/prerender/prerender_test_utils.h" | 14 #include "chrome/browser/prerender/prerender_test_utils.h" |
| 15 #include "chrome/browser/profiles/profile.h" | 15 #include "chrome/browser/profiles/profile.h" |
| 16 #include "chrome/browser/task_manager/task_manager_browsertest_util.h" | 16 #include "chrome/browser/task_manager/task_manager_browsertest_util.h" |
| 17 #include "chrome/browser/ui/browser.h" | 17 #include "chrome/browser/ui/browser.h" |
| 18 #include "chrome/browser/ui/browser_commands.h" | 18 #include "chrome/browser/ui/browser_commands.h" |
| 19 #include "chrome/browser/ui/tabs/tab_strip_model.h" | 19 #include "chrome/browser/ui/tabs/tab_strip_model.h" |
| 20 #include "chrome/common/chrome_switches.h" | 20 #include "chrome/common/chrome_switches.h" |
| 21 #include "chrome/grit/generated_resources.h" | 21 #include "chrome/grit/generated_resources.h" |
| 22 #include "chrome/test/base/ui_test_utils.h" | 22 #include "chrome/test/base/ui_test_utils.h" |
| 23 #include "content/public/common/content_switches.h" | 23 #include "content/public/common/content_switches.h" |
| 24 #include "content/public/common/url_constants.h" | 24 #include "content/public/common/url_constants.h" |
| 25 #include "content/public/test/browser_test_utils.h" | 25 #include "content/public/test/browser_test_utils.h" |
| 26 #include "net/base/escape.h" | 26 #include "net/base/escape.h" |
| 27 #include "net/base/load_flags.h" | |
| 27 #include "net/dns/mock_host_resolver.h" | 28 #include "net/dns/mock_host_resolver.h" |
| 28 #include "net/test/embedded_test_server/request_handler_util.h" | 29 #include "net/test/embedded_test_server/request_handler_util.h" |
| 29 #include "testing/gtest/include/gtest/gtest.h" | 30 #include "testing/gtest/include/gtest/gtest.h" |
| 30 #include "ui/base/l10n/l10n_util.h" | 31 #include "ui/base/l10n/l10n_util.h" |
| 31 | 32 |
| 32 using prerender::test_utils::CreateCountingInterceptorOnIO; | |
| 33 using prerender::test_utils::CreatePrefetchOnlyInterceptorOnIO; | |
| 34 using prerender::test_utils::DestructionWaiter; | 33 using prerender::test_utils::DestructionWaiter; |
| 35 using prerender::test_utils::RequestCounter; | 34 using prerender::test_utils::RequestCounter; |
| 36 using prerender::test_utils::TestPrerender; | 35 using prerender::test_utils::TestPrerender; |
| 37 | 36 |
| 38 namespace prerender { | 37 namespace prerender { |
| 39 | 38 |
| 40 // These URLs used for test resources must be relative with the exception of | 39 // These URLs used for test resources must be relative with the exception of |
| 41 // |kPrefetchLoaderPath|. | 40 // |kPrefetchLoaderPath|. |
| 42 const char kPrefetchImagePage[] = "prerender/prefetch_image.html"; | 41 const char kPrefetchImagePage[] = "prerender/prefetch_image.html"; |
| 43 const char kPrefetchJpeg[] = "prerender/image.jpeg"; | 42 const char kPrefetchJpeg[] = "prerender/image.jpeg"; |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 76 } | 75 } |
| 77 | 76 |
| 78 // As above, but specify the data path and URL separately. | 77 // As above, but specify the data path and URL separately. |
| 79 void CountRequestForUrl(const GURL& url, | 78 void CountRequestForUrl(const GURL& url, |
| 80 const std::string& path_str, | 79 const std::string& path_str, |
| 81 RequestCounter* counter) { | 80 RequestCounter* counter) { |
| 82 base::FilePath url_file = ui_test_utils::GetTestFilePath( | 81 base::FilePath url_file = ui_test_utils::GetTestFilePath( |
| 83 base::FilePath(), base::FilePath::FromUTF8Unsafe(path_str)); | 82 base::FilePath(), base::FilePath::FromUTF8Unsafe(path_str)); |
| 84 content::BrowserThread::PostTask( | 83 content::BrowserThread::PostTask( |
| 85 content::BrowserThread::IO, FROM_HERE, | 84 content::BrowserThread::IO, FROM_HERE, |
| 86 base::Bind(&CreateCountingInterceptorOnIO, url, url_file, | 85 base::Bind(&prerender::test_utils::CreateCountingInterceptorOnIO, url, |
| 87 counter->AsWeakPtr())); | 86 url_file, counter->AsWeakPtr())); |
| 88 } | 87 } |
| 89 | 88 |
| 90 protected: | 89 protected: |
| 91 std::unique_ptr<TestPrerender> PrefetchFromURL( | 90 std::unique_ptr<TestPrerender> PrefetchFromURL( |
| 92 const GURL& target_url, | 91 const GURL& target_url, |
| 93 FinalStatus expected_final_status) { | 92 FinalStatus expected_final_status) { |
| 94 GURL loader_url = ServeLoaderURL( | 93 GURL loader_url = ServeLoaderURL( |
| 95 kPrefetchLoaderPath, "REPLACE_WITH_PREFETCH_URL", target_url, ""); | 94 kPrefetchLoaderPath, "REPLACE_WITH_PREFETCH_URL", target_url, ""); |
| 96 std::vector<FinalStatus> expected_final_status_queue(1, | 95 std::vector<FinalStatus> expected_final_status_queue(1, |
| 97 expected_final_status); | 96 expected_final_status); |
| (...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 129 script2_counter.WaitForCount(0); | 128 script2_counter.WaitForCount(0); |
| 130 | 129 |
| 131 // Verify that the page load did not happen. | 130 // Verify that the page load did not happen. |
| 132 test_prerender->WaitForLoads(0); | 131 test_prerender->WaitForLoads(0); |
| 133 } | 132 } |
| 134 | 133 |
| 135 // Check that the LOAD_PREFETCH flag is set. | 134 // Check that the LOAD_PREFETCH flag is set. |
| 136 IN_PROC_BROWSER_TEST_F(NoStatePrefetchBrowserTest, PrefetchLoadFlag) { | 135 IN_PROC_BROWSER_TEST_F(NoStatePrefetchBrowserTest, PrefetchLoadFlag) { |
| 137 RequestCounter main_counter; | 136 RequestCounter main_counter; |
| 138 RequestCounter script_counter; | 137 RequestCounter script_counter; |
| 139 content::BrowserThread::PostTask( | 138 auto verify_prefetch_only = base::Bind([](net::URLRequest* request) { |
| 140 content::BrowserThread::IO, FROM_HERE, | 139 EXPECT_TRUE(request->load_flags() & net::LOAD_PREFETCH); |
| 141 base::Bind(&CreatePrefetchOnlyInterceptorOnIO, | 140 }); |
| 142 src_server()->GetURL(MakeAbsolute(kPrefetchPage)), | 141 |
| 143 main_counter.AsWeakPtr())); | 142 prerender::test_utils::InterceptRequestAndCount( |
| 144 content::BrowserThread::PostTask( | 143 src_server()->GetURL(MakeAbsolute(kPrefetchPage)), &main_counter, |
| 145 content::BrowserThread::IO, FROM_HERE, | 144 verify_prefetch_only); |
| 146 base::Bind(&CreatePrefetchOnlyInterceptorOnIO, | 145 prerender::test_utils::InterceptRequestAndCount( |
| 147 src_server()->GetURL(MakeAbsolute(kPrefetchScript)), | 146 src_server()->GetURL(MakeAbsolute(kPrefetchScript)), &script_counter, |
| 148 script_counter.AsWeakPtr())); | 147 verify_prefetch_only); |
| 149 | 148 |
| 150 std::unique_ptr<TestPrerender> test_prerender = | 149 std::unique_ptr<TestPrerender> test_prerender = |
| 151 PrefetchFromFile(kPrefetchPage, FINAL_STATUS_NOSTATE_PREFETCH_FINISHED); | 150 PrefetchFromFile(kPrefetchPage, FINAL_STATUS_NOSTATE_PREFETCH_FINISHED); |
| 152 main_counter.WaitForCount(1); | 151 main_counter.WaitForCount(1); |
| 153 script_counter.WaitForCount(1); | 152 script_counter.WaitForCount(1); |
| 154 | 153 |
| 155 // Verify that the page load did not happen. | 154 // Verify that the page load did not happen. |
| 156 test_prerender->WaitForLoads(0); | 155 test_prerender->WaitForLoads(0); |
| 157 } | 156 } |
| 158 | 157 |
| (...skipping 137 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 296 | 295 |
| 297 // Checks that the load flags are set correctly for all resources in a 301 | 296 // Checks that the load flags are set correctly for all resources in a 301 |
| 298 // redirect chain. | 297 // redirect chain. |
| 299 IN_PROC_BROWSER_TEST_F(NoStatePrefetchBrowserTest, Prefetch301LoadFlags) { | 298 IN_PROC_BROWSER_TEST_F(NoStatePrefetchBrowserTest, Prefetch301LoadFlags) { |
| 300 std::string redirect_path = | 299 std::string redirect_path = |
| 301 "/server-redirect/?" + | 300 "/server-redirect/?" + |
| 302 net::EscapeQueryParamValue(MakeAbsolute(kPrefetchPage), false); | 301 net::EscapeQueryParamValue(MakeAbsolute(kPrefetchPage), false); |
| 303 GURL redirect_url = src_server()->GetURL(redirect_path); | 302 GURL redirect_url = src_server()->GetURL(redirect_path); |
| 304 GURL page_url = src_server()->GetURL(MakeAbsolute(kPrefetchPage)); | 303 GURL page_url = src_server()->GetURL(MakeAbsolute(kPrefetchPage)); |
| 305 RequestCounter redirect_counter; | 304 RequestCounter redirect_counter; |
| 306 content::BrowserThread::PostTask( | 305 auto verify_prefetch_only = base::Bind([](net::URLRequest* request) { |
| 307 content::BrowserThread::IO, FROM_HERE, | 306 EXPECT_TRUE(request->load_flags() & net::LOAD_PREFETCH); |
| 308 base::Bind(&CreatePrefetchOnlyInterceptorOnIO, redirect_url, | 307 }); |
| 309 redirect_counter.AsWeakPtr())); | 308 prerender::test_utils::InterceptRequestAndCount( |
| 309 redirect_url, &redirect_counter, verify_prefetch_only); | |
| 310 RequestCounter page_counter; | 310 RequestCounter page_counter; |
| 311 content::BrowserThread::PostTask( | 311 prerender::test_utils::InterceptRequestAndCount(page_url, &page_counter, |
| 312 content::BrowserThread::IO, FROM_HERE, | 312 verify_prefetch_only); |
| 313 base::Bind(&CreatePrefetchOnlyInterceptorOnIO, page_url, | |
| 314 page_counter.AsWeakPtr())); | |
| 315 PrefetchFromFile(redirect_path, FINAL_STATUS_NOSTATE_PREFETCH_FINISHED); | 313 PrefetchFromFile(redirect_path, FINAL_STATUS_NOSTATE_PREFETCH_FINISHED); |
| 316 redirect_counter.WaitForCount(1); | 314 redirect_counter.WaitForCount(1); |
| 317 page_counter.WaitForCount(1); | 315 page_counter.WaitForCount(1); |
| 318 } | 316 } |
| 319 | 317 |
| 320 // Checks that a subresource 301 redirect is followed. | 318 // Checks that a subresource 301 redirect is followed. |
| 321 IN_PROC_BROWSER_TEST_F(NoStatePrefetchBrowserTest, Prefetch301Subresource) { | 319 IN_PROC_BROWSER_TEST_F(NoStatePrefetchBrowserTest, Prefetch301Subresource) { |
| 322 RequestCounter script_counter; | 320 RequestCounter script_counter; |
| 323 CountRequestFor(kPrefetchScript, &script_counter); | 321 CountRequestFor(kPrefetchScript, &script_counter); |
| 324 PrefetchFromFile(kPrefetchSubresourceRedirectPage, | 322 PrefetchFromFile(kPrefetchSubresourceRedirectPage, |
| (...skipping 166 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 491 EXPECT_TRUE(std::find(urls.begin(), urls.end(), navigated_url) != urls.end()); | 489 EXPECT_TRUE(std::find(urls.begin(), urls.end(), navigated_url) != urls.end()); |
| 492 | 490 |
| 493 // Check that the URL that was prefetched is not in history. | 491 // Check that the URL that was prefetched is not in history. |
| 494 EXPECT_TRUE(std::find(urls.begin(), urls.end(), prefetched_url) == | 492 EXPECT_TRUE(std::find(urls.begin(), urls.end(), prefetched_url) == |
| 495 urls.end()); | 493 urls.end()); |
| 496 | 494 |
| 497 // The loader URL is the remaining entry. | 495 // The loader URL is the remaining entry. |
| 498 EXPECT_EQ(2U, urls.size()); | 496 EXPECT_EQ(2U, urls.size()); |
| 499 } | 497 } |
| 500 | 498 |
| 499 // Checks that prefetch requests have net::IDLE priority. | |
| 500 // On Android requests from prerenders do not get downgraded priority. | |
| 501 // See: https://crbug.com/652746. | |
| 502 #if defined(OS_ANDROID) | |
| 503 #define MAYBE_IssuesIdlePriorityRequests DISABLED_IssuesIdlePriorityRequests | |
|
droger
2016/12/01 10:57:00
Should we keep the test enabled on Android, but ch
pasko
2016/12/01 12:04:54
Good idea. Done. PTAL.
Since to bind a lambda the
| |
| 504 #else | |
| 505 #define MAYBE_IssuesIdlePriorityRequests IssuesIdlePriorityRequests | |
| 506 #endif | |
| 507 IN_PROC_BROWSER_TEST_F(NoStatePrefetchBrowserTest, | |
| 508 MAYBE_IssuesIdlePriorityRequests) { | |
| 509 GURL script_url = src_server()->GetURL(MakeAbsolute(kPrefetchScript)); | |
| 510 RequestCounter script_counter; | |
| 511 prerender::test_utils::InterceptRequestAndCount( | |
| 512 script_url, &script_counter, base::Bind([](net::URLRequest* request) { | |
| 513 EXPECT_EQ(net::IDLE, request->priority()); | |
| 514 })); | |
| 515 PrefetchFromFile(kPrefetchPage, FINAL_STATUS_NOSTATE_PREFETCH_FINISHED); | |
| 516 script_counter.WaitForCount(1); | |
| 517 } | |
| 518 | |
| 501 } // namespace prerender | 519 } // namespace prerender |
| OLD | NEW |