Chromium Code Reviews| Index: chrome/browser/app_controller_mac_browsertest.mm |
| diff --git a/chrome/browser/app_controller_mac_browsertest.mm b/chrome/browser/app_controller_mac_browsertest.mm |
| index 63324c06fb6c95d6849ad57e71f699fc6fe497c0..fdfd7226181cd9cbfa56e99f2e95517348641a00 100644 |
| --- a/chrome/browser/app_controller_mac_browsertest.mm |
| +++ b/chrome/browser/app_controller_mac_browsertest.mm |
| @@ -15,6 +15,7 @@ |
| #include "base/mac/scoped_nsobject.h" |
| #include "base/message_loop/message_loop.h" |
| #include "base/run_loop.h" |
| + |
| #include "base/strings/sys_string_conversions.h" |
| #include "base/strings/utf_string_conversions.h" |
| #include "base/threading/thread_restrictions.h" |
| @@ -23,7 +24,9 @@ |
| #include "chrome/browser/apps/app_browsertest_util.h" |
| #include "chrome/browser/bookmarks/bookmark_model_factory.h" |
| #include "chrome/browser/browser_process.h" |
| +#include "chrome/browser/chrome_notification_types.h" |
| #include "chrome/browser/history/history_service_factory.h" |
| +#include "chrome/browser/prefs/session_startup_pref.h" |
| #include "chrome/browser/profiles/profile_attributes_entry.h" |
| #include "chrome/browser/profiles/profile_attributes_storage.h" |
| #include "chrome/browser/profiles/profile_manager.h" |
| @@ -46,8 +49,10 @@ |
| #include "components/bookmarks/test/bookmark_test_helpers.h" |
| #include "components/prefs/pref_service.h" |
| #include "content/public/browser/navigation_controller.h" |
| +#include "content/public/browser/notification_service.h" |
| #include "content/public/browser/web_contents.h" |
| #include "content/public/test/browser_test_utils.h" |
| +#include "content/public/test/repeated_notification_observer.h" |
| #include "content/public/test/test_navigation_observer.h" |
| #include "extensions/browser/app_window/app_window_registry.h" |
| #include "extensions/common/extension.h" |
| @@ -56,7 +61,7 @@ |
| namespace { |
| -GURL g_open_shortcut_url = GURL::EmptyGURL(); |
| +GURL g_open_shortcut_url = GURL("https://localhost"); |
| // Returns an Apple Event that instructs the application to open |url|. |
| NSAppleEventDescriptor* AppleEventToOpenUrl(const GURL& url) { |
| @@ -103,9 +108,6 @@ - (void)applicationWillFinishLaunching:(NSNotification*)notification; |
| @implementation TestOpenShortcutOnStartup |
| - (void)applicationWillFinishLaunching:(NSNotification*)notification { |
| - if (!g_open_shortcut_url.is_valid()) |
| - return; |
| - |
| SendAppleEventToOpenUrlToAppController(g_open_shortcut_url); |
| } |
| @@ -380,9 +382,6 @@ void SetUpInProcessBrowserTestFixture() override { |
| ASSERT_TRUE(destination != NULL); |
| method_exchangeImplementations(original, destination); |
| - |
| - ASSERT_TRUE(embedded_test_server()->Start()); |
| - g_open_shortcut_url = embedded_test_server()->GetURL("/simple.html"); |
| } |
| void SetUpCommandLine(base::CommandLine* command_line) override { |
| @@ -401,6 +400,206 @@ void SetUpCommandLine(base::CommandLine* command_line) override { |
| ->GetLastCommittedURL()); |
| } |
| +const char kSessionURL[] = "https://example.com/session.html"; |
| +const char kPresetURL[] = "https://example.com/preset.html"; |
| +const char kUrlToOpen[] = "https://example.com/shortcut.html"; |
| + |
| +class AppControllerOpenShortcutOnStartupBrowserTest |
|
sky
2017/06/08 19:17:49
What is mac specific about this test? It seems lik
eugenebng
2017/06/09 13:16:22
Implementation (the way URLs/shortcuts are opened)
sky
2017/06/09 15:29:51
I didn't realize the base has obective-c specifics
|
| + : public AppControllerOpenShortcutBrowserTest, |
| + public testing::WithParamInterface<SessionStartupPref::Type> { |
| + public: |
| + AppControllerOpenShortcutOnStartupBrowserTest() |
| + : session_startup_pref_(GetParam()) {} |
| + virtual ~AppControllerOpenShortcutOnStartupBrowserTest() {} |
| + |
| + void SetUpInProcessBrowserTestFixture() override { |
| + // Don't open URL via AppControllerOpenShortcutBrowserTest in PRE test, |
| + // PRE test should only prepare session-to-restore. |
| + if (!base::StartsWith( |
| + testing::UnitTest::GetInstance()->current_test_info()->name(), |
| + "PRE_", base::CompareCase::SENSITIVE)) { |
| + AppControllerOpenShortcutBrowserTest::SetUpInProcessBrowserTestFixture(); |
| + } |
| + } |
| + |
| + void SetUpOnMainThread() override { |
| + ASSERT_TRUE(embedded_test_server()->Start()); |
| + SessionStartupPref pref(GetParam()); |
| + pref.urls.push_back(GURL(kPresetURL)); |
| + SessionStartupPref::SetStartupPref(browser()->profile(), pref); |
| + InProcessBrowserTest::SetUpOnMainThread(); |
| + } |
| + |
| + protected: |
| + void SetUpCommandLine(base::CommandLine* command_line) override { |
| + set_open_about_blank_on_browser_launch(false); |
| + // Skip AppControllerOpenShortcutBrowserTest::SetUpCommandLine, which adds |
| + // startup URL. |
| + InProcessBrowserTest::SetUpCommandLine(command_line); |
| + } |
| + |
| + SessionStartupPref::Type GetSessionStartupPref() { |
| + return session_startup_pref_; |
| + } |
| + |
| + private: |
| + SessionStartupPref::Type session_startup_pref_; |
| + |
| + DISALLOW_COPY_AND_ASSIGN(AppControllerOpenShortcutOnStartupBrowserTest); |
| +}; |
| + |
| +IN_PROC_BROWSER_TEST_P(AppControllerOpenShortcutOnStartupBrowserTest, |
| + PRE_OpenURL) { |
| + // Prepare a session to restore in main test body. |
| + ui_test_utils::NavigateToURL(browser(), GURL(kSessionURL)); |
| + ASSERT_EQ(1, browser()->tab_strip_model()->count()); |
| +} |
| + |
| +// This test checks that when AppleEvent on opening URL is received during |
| +// browser starup, that URL is opened and located properly alongside restored |
| +// session or startup URLs. |
| +// Emulates opening local file or URL from other application when chromium |
| +// application is not started. |
| +IN_PROC_BROWSER_TEST_P(AppControllerOpenShortcutOnStartupBrowserTest, OpenURL) { |
| + TabStripModel* tab_strip = browser()->tab_strip_model(); |
| + if (GetSessionStartupPref() == SessionStartupPref::DEFAULT) { |
| + // Open NTP startup setting - tab opened via shortcut should replace NTP. |
| + EXPECT_EQ(1, tab_strip->count()); |
| + } else if (GetSessionStartupPref() == SessionStartupPref::LAST) { |
| + // Restore sesion on startup - expect tab of that session. |
| + EXPECT_EQ(2, tab_strip->count()); |
| + EXPECT_EQ(kSessionURL, tab_strip->GetWebContentsAt(0)->GetURL().spec()); |
| + } else if (GetSessionStartupPref() == SessionStartupPref::URLS) { |
| + // Open specific set of pages startup setting - expect that set of pages. |
| + EXPECT_EQ(2, tab_strip->count()); |
| + EXPECT_EQ(kPresetURL, tab_strip->GetWebContentsAt(0)->GetURL().spec()); |
| + } else { |
| + NOTREACHED() << "Unknown session startup pref, not covered by test."; |
| + } |
| + // Tab opened via shortcut should be the last tab and shold be active. |
| + EXPECT_EQ( |
| + g_open_shortcut_url.spec(), |
| + tab_strip->GetWebContentsAt(tab_strip->count() - 1)->GetURL().spec()); |
| + EXPECT_EQ(tab_strip->count() - 1, tab_strip->active_index()); |
| +} |
| + |
| +INSTANTIATE_TEST_CASE_P(AppControllerOpenShortcutOnStartupPrefsAny, |
| + AppControllerOpenShortcutOnStartupBrowserTest, |
| + testing::Values(SessionStartupPref::DEFAULT, |
| + SessionStartupPref::LAST, |
| + SessionStartupPref::URLS)); |
| + |
| +class AppControllerOpenShortcutInBrowserTest |
| + : public InProcessBrowserTest, |
| + public testing::WithParamInterface<SessionStartupPref::Type> { |
| + public: |
| + AppControllerOpenShortcutInBrowserTest() |
| + : session_startup_pref_(GetParam()) {} |
| + |
| + protected: |
| + SessionStartupPref::Type GetSessionStartupPref() { |
| + return session_startup_pref_; |
| + } |
| + |
| + void SetUpOnMainThread() override { |
| + SessionStartupPref pref(session_startup_pref_); |
| + pref.urls.push_back(GURL(kPresetURL)); |
| + SessionStartupPref::SetStartupPref(browser()->profile(), pref); |
| + InProcessBrowserTest::SetUpOnMainThread(); |
| + } |
| + |
| + void SetUpCommandLine(base::CommandLine* command_line) override { |
| + set_open_about_blank_on_browser_launch(false); |
| + } |
| + |
| + private: |
| + SessionStartupPref::Type session_startup_pref_; |
| + |
| + DISALLOW_COPY_AND_ASSIGN(AppControllerOpenShortcutInBrowserTest); |
| +}; |
| + |
| +IN_PROC_BROWSER_TEST_P(AppControllerOpenShortcutInBrowserTest, |
| + PRE_OpenShortcutInBrwowserWithWindow) { |
|
sky
2017/06/08 19:17:49
Looks like you misspelled browser in a bunch of pl
eugenebng
2017/06/09 13:16:22
I'm sorry. fixed those typos.
|
| + // Prepare a session to restore in main test body. |
| + ui_test_utils::NavigateToURL(browser(), GURL(kSessionURL)); |
| + ASSERT_EQ(1, browser()->tab_strip_model()->count()); |
| +} |
| + |
| +// This test checks that when AppleEvent on opening URL is received by already |
| +// started browser with window, that URL opens in a tab next to existing tabs. |
| +// This needs to be TEST_P (with SessionStartupPref::Type) parameter to |
| +// ensure that opening URL logic will not by mistake restore sesiion or open |
| +// startup URLs. |
| +IN_PROC_BROWSER_TEST_P(AppControllerOpenShortcutInBrowserTest, |
| + OpenShortcutInBrwowserWithWindow) { |
| + ui_test_utils::NavigateToURL(browser(), GURL(kSessionURL)); |
| + ASSERT_EQ(1, browser()->tab_strip_model()->count()); |
| + SendAppleEventToOpenUrlToAppController(GURL(kUrlToOpen)); |
| + content::TestNavigationObserver event_navigation_observer( |
| + browser()->tab_strip_model()->GetActiveWebContents()); |
| + event_navigation_observer.Wait(); |
| + |
| + ASSERT_EQ(2, browser()->tab_strip_model()->count()); |
| + TabStripModel* tab_strip = browser()->tab_strip_model(); |
| + EXPECT_EQ(kUrlToOpen, tab_strip->GetWebContentsAt(1)->GetURL().spec()); |
| + EXPECT_EQ(1, tab_strip->active_index()); |
| +} |
| + |
| +IN_PROC_BROWSER_TEST_P(AppControllerOpenShortcutInBrowserTest, |
| + PRE_OpenShortcutInBrwowserWithoutWindow) { |
| + // Prepare a session to restore in main test body. |
| + ui_test_utils::NavigateToURL(browser(), GURL(kSessionURL)); |
| + ASSERT_EQ(1, browser()->tab_strip_model()->count()); |
| +} |
| + |
| +// This test checks that when AppleEvent on opening URL is received by |
| +// chromium application withot windows, that URL is opened, alongside with |
| +// restored session if corresponding setting is enabled. |
| +IN_PROC_BROWSER_TEST_P(AppControllerOpenShortcutInBrowserTest, |
| + OpenShortcutInBrwowserWithoutWindow) { |
| + ui_test_utils::NavigateToURL(browser(), GURL(kSessionURL)); |
| + content::RepeatedNotificationObserver close_observer( |
| + chrome::NOTIFICATION_BROWSER_CLOSED, 1); |
| + browser()->window()->Close(); |
| + close_observer.Wait(); |
| + |
| + content::RepeatedNotificationObserver open_observer( |
| + chrome::NOTIFICATION_TAB_ADDED, 1); |
| + SendAppleEventToOpenUrlToAppController(GURL(kUrlToOpen)); |
| + |
| + open_observer.Wait(); |
| + |
| + Browser* browser = BrowserList::GetInstance()->GetLastActive(); |
| + TabStripModel* tab_strip = browser->tab_strip_model(); |
| + |
| + if (GetSessionStartupPref() == SessionStartupPref::DEFAULT) { |
| + // Open NTP startup setting - tab opened via shortcut should replace NTP. |
| + ASSERT_EQ(1, tab_strip->count()); |
| + } else if (GetSessionStartupPref() == SessionStartupPref::LAST) { |
| + // Restore sesion on startup - expect tab of that session. |
| + ASSERT_EQ(2, tab_strip->count()); |
| + EXPECT_EQ(kSessionURL, tab_strip->GetWebContentsAt(0)->GetURL().spec()); |
| + } else if (GetSessionStartupPref() == SessionStartupPref::URLS) { |
| + // Open specific set of pages startup setting - when Chromium application |
| + // is already started, do NOT expect these pages to be opened. |
| + ASSERT_EQ(1, tab_strip->count()); |
| + } else { |
| + NOTREACHED() << "Unknown session startup pref, not covered by test."; |
| + } |
| + |
| + // Tab opened via shortcut should be the last tab and shold be active. |
| + EXPECT_EQ( |
| + kUrlToOpen, |
| + tab_strip->GetWebContentsAt(tab_strip->count() - 1)->GetURL().spec()); |
| + EXPECT_EQ(tab_strip->count() - 1, tab_strip->active_index()); |
| +} |
| + |
| +INSTANTIATE_TEST_CASE_P(AppControllerOpenShortcutInBrowserPrefsAny, |
| + AppControllerOpenShortcutInBrowserTest, |
| + testing::Values(SessionStartupPref::DEFAULT, |
| + SessionStartupPref::LAST, |
| + SessionStartupPref::URLS)); |
| + |
| class AppControllerReplaceNTPBrowserTest : public InProcessBrowserTest { |
| protected: |
| AppControllerReplaceNTPBrowserTest() {} |