Chromium Code Reviews| OLD | NEW |
|---|---|
| (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/chrome_notification_types.h" | |
| 6 #include "chrome/browser/extensions/extension_browsertest.h" | |
| 7 #include "chrome/browser/ui/browser.h" | |
| 8 #include "chrome/browser/ui/browser_commands.h" | |
| 9 #include "chrome/browser/ui/tabs/tab_strip_model.h" | |
| 10 #include "chrome/common/url_constants.h" | |
| 11 #include "chrome/test/base/ui_test_utils.h" | |
| 12 #include "content/public/browser/navigation_entry.h" | |
|
benwells
2017/06/22 01:55:20
Nit: I don't think this include is needed.
calamity
2017/06/22 04:24:49
This is GetActiveEntry()->GetVirtualURL().
benwells
2017/06/22 04:27:12
Acknowledged.
| |
| 13 #include "content/public/browser/notification_service.h" | |
| 14 #include "content/public/browser/notification_types.h" | |
| 15 #include "content/public/browser/render_frame_host.h" | |
| 16 #include "content/public/browser/web_contents.h" | |
| 17 #include "content/public/test/browser_test_utils.h" | |
| 18 #include "extensions/common/constants.h" | |
| 19 #include "net/test/embedded_test_server/embedded_test_server.h" | |
| 20 #include "url/gurl.h" | |
| 21 | |
| 22 typedef ExtensionBrowserTest ViewExtensionSourceTest; | |
| 23 | |
| 24 // Verify that restoring a view-source tab for a Chrome extension works | |
| 25 // properly. See https://crbug.com/699428. | |
| 26 IN_PROC_BROWSER_TEST_F(ViewExtensionSourceTest, ViewSourceTabRestore) { | |
| 27 ASSERT_TRUE(embedded_test_server()->Start()); | |
| 28 | |
| 29 LoadExtension( | |
| 30 test_data_dir_.AppendASCII("browsertest/url_rewrite/bookmarks")); | |
| 31 | |
| 32 // Go to the Chrome bookmarks URL. It should redirect to the bookmark | |
| 33 // manager Chrome extension. | |
| 34 GURL bookmarks_url(chrome::kChromeUIBookmarksURL); | |
| 35 ui_test_utils::NavigateToURL(browser(), bookmarks_url); | |
| 36 EXPECT_TRUE(chrome::CanViewSource(browser())); | |
| 37 content::WebContents* bookmarks_tab = | |
| 38 browser()->tab_strip_model()->GetActiveWebContents(); | |
| 39 GURL bookmarks_extension_url = | |
| 40 bookmarks_tab->GetMainFrame()->GetLastCommittedURL(); | |
| 41 EXPECT_TRUE(bookmarks_extension_url.SchemeIs(extensions::kExtensionScheme)); | |
| 42 | |
| 43 // Open a new view-source tab for that URL. | |
| 44 GURL view_source_url(content::kViewSourceScheme + std::string(":") + | |
| 45 bookmarks_extension_url.spec()); | |
| 46 AddTabAtIndex(1, view_source_url, ui::PAGE_TRANSITION_TYPED); | |
| 47 content::WebContents* view_source_tab = | |
| 48 browser()->tab_strip_model()->GetActiveWebContents(); | |
| 49 EXPECT_EQ(view_source_url, view_source_tab->GetVisibleURL()); | |
| 50 EXPECT_EQ(view_source_url, | |
| 51 view_source_tab->GetController().GetActiveEntry()->GetVirtualURL()); | |
| 52 EXPECT_EQ(bookmarks_extension_url, | |
| 53 view_source_tab->GetMainFrame()->GetLastCommittedURL()); | |
| 54 EXPECT_FALSE(chrome::CanViewSource(browser())); | |
| 55 | |
| 56 // Close the view-source tab. | |
| 57 chrome::CloseTab(browser()); | |
| 58 ASSERT_EQ(1, browser()->tab_strip_model()->count()); | |
| 59 | |
| 60 // Restore the tab. In the bug, the restored navigation was blocked, and we | |
| 61 // ended up showing view-source of an about:blank page. | |
| 62 content::WindowedNotificationObserver tab_added_observer( | |
| 63 chrome::NOTIFICATION_TAB_PARENTED, | |
| 64 content::NotificationService::AllSources()); | |
| 65 chrome::RestoreTab(browser()); | |
| 66 tab_added_observer.Wait(); | |
| 67 view_source_tab = browser()->tab_strip_model()->GetActiveWebContents(); | |
| 68 WaitForLoadStop(view_source_tab); | |
| 69 | |
| 70 // Verify the browser-side URLs. Note that without view-source, the | |
| 71 // bookmarks extension visible URL would be rewritten to chrome://bookmarks, | |
| 72 // but with view-source, we should still see it as | |
| 73 // view-source:chrome-extension://.../. | |
| 74 EXPECT_EQ(view_source_url, view_source_tab->GetVisibleURL()); | |
| 75 EXPECT_EQ(view_source_url, | |
| 76 view_source_tab->GetController().GetActiveEntry()->GetVirtualURL()); | |
| 77 EXPECT_EQ(bookmarks_extension_url, | |
| 78 view_source_tab->GetMainFrame()->GetLastCommittedURL()); | |
| 79 EXPECT_FALSE(chrome::CanViewSource(browser())); | |
| 80 | |
| 81 // Verify that the view-source content is not empty, and that the | |
| 82 // renderer-side URL is correct. | |
| 83 int view_source_length; | |
| 84 EXPECT_TRUE(ExecuteScriptAndExtractInt( | |
| 85 view_source_tab, | |
| 86 "domAutomationController.send(document.body.innerText.length)", | |
| 87 &view_source_length)); | |
| 88 EXPECT_GT(view_source_length, 0); | |
| 89 | |
| 90 std::string location; | |
| 91 EXPECT_TRUE(ExecuteScriptAndExtractString( | |
| 92 view_source_tab, "domAutomationController.send(location.href)", | |
| 93 &location)); | |
| 94 EXPECT_EQ(bookmarks_extension_url, location); | |
| 95 } | |
| OLD | NEW |