| Index: chrome/browser/extensions/window_open_apitest.cc
|
| diff --git a/chrome/browser/extensions/window_open_apitest.cc b/chrome/browser/extensions/window_open_apitest.cc
|
| index b3d2b1dbde04ae564c355dba575eeabd80aef070..c09e4752e9a9d5c2c11b69f8ef0395c24d0a06ce 100644
|
| --- a/chrome/browser/extensions/window_open_apitest.cc
|
| +++ b/chrome/browser/extensions/window_open_apitest.cc
|
| @@ -3,10 +3,13 @@
|
| // found in the LICENSE file.
|
|
|
| #include "base/command_line.h"
|
| +#include "base/memory/scoped_vector.h"
|
| #include "chrome/browser/extensions/extension_apitest.h"
|
| +#include "chrome/browser/extensions/extension_test_message_listener.h"
|
| #include "chrome/browser/ui/browser.h"
|
| #include "chrome/browser/ui/browser_list.h"
|
| #include "chrome/common/chrome_switches.h"
|
| +#include "chrome/common/extensions/extension.h"
|
| #include "chrome/test/base/ui_test_utils.h"
|
| #include "net/base/mock_host_resolver.h"
|
|
|
| @@ -21,16 +24,19 @@ IN_PROC_BROWSER_TEST_F(ExtensionApiTest, DISABLED_WindowOpen) {
|
| EXPECT_TRUE(catcher.GetNextResult()) << catcher.message();
|
| }
|
|
|
| -void WaitForTabsAndPopups(Browser* browser, int num_tabs, int num_popups) {
|
| +void WaitForTabsAndPopups(Browser* browser,
|
| + int num_tabs,
|
| + int num_popups,
|
| + int num_panels) {
|
| // We start with one tab and one browser already open.
|
| ++num_tabs;
|
| - size_t num_browsers = static_cast<size_t>(num_popups) + 1;
|
| + size_t num_browsers = static_cast<size_t>(num_popups + num_panels) + 1;
|
|
|
| const base::TimeDelta kWaitTime = base::TimeDelta::FromSeconds(15);
|
| base::TimeTicks end_time = base::TimeTicks::Now() + kWaitTime;
|
| while (base::TimeTicks::Now() < end_time) {
|
| - if (BrowserList::GetBrowserCount(browser->profile()) >= num_browsers &&
|
| - browser->tab_count() >= num_tabs)
|
| + if (BrowserList::GetBrowserCount(browser->profile()) == num_browsers &&
|
| + browser->tab_count() == num_tabs)
|
| break;
|
|
|
| MessageLoopForUI::current()->RunAllPending();
|
| @@ -39,6 +45,8 @@ void WaitForTabsAndPopups(Browser* browser, int num_tabs, int num_popups) {
|
| EXPECT_EQ(num_browsers, BrowserList::GetBrowserCount(browser->profile()));
|
| EXPECT_EQ(num_tabs, browser->tab_count());
|
|
|
| + int num_popups_seen = 0;
|
| + int num_panels_seen = 0;
|
| for (BrowserList::const_iterator iter = BrowserList::begin();
|
| iter != BrowserList::end(); ++iter) {
|
| if (*iter == browser)
|
| @@ -46,7 +54,13 @@ void WaitForTabsAndPopups(Browser* browser, int num_tabs, int num_popups) {
|
|
|
| // Check for TYPE_POPUP or TYPE_PANEL.
|
| EXPECT_TRUE((*iter)->is_type_popup() || (*iter)->is_type_panel());
|
| + if ((*iter)->is_type_popup())
|
| + ++num_popups_seen;
|
| + else
|
| + ++num_panels_seen;
|
| }
|
| + EXPECT_EQ(num_popups, num_popups_seen);
|
| + EXPECT_EQ(num_panels, num_panels_seen);
|
| }
|
|
|
| IN_PROC_BROWSER_TEST_F(ExtensionApiTest, BrowserIsApp) {
|
| @@ -55,7 +69,7 @@ IN_PROC_BROWSER_TEST_F(ExtensionApiTest, BrowserIsApp) {
|
| ASSERT_TRUE(LoadExtension(
|
| test_data_dir_.AppendASCII("window_open").AppendASCII("browser_is_app")));
|
|
|
| - WaitForTabsAndPopups(browser(), 0, 2);
|
| + WaitForTabsAndPopups(browser(), 0, 2, 0);
|
|
|
| for (BrowserList::const_iterator iter = BrowserList::begin();
|
| iter != BrowserList::end(); ++iter) {
|
| @@ -73,7 +87,7 @@ IN_PROC_BROWSER_TEST_F(ExtensionApiTest, WindowOpenPopupDefault) {
|
|
|
| const int num_tabs = 1;
|
| const int num_popups = 0;
|
| - WaitForTabsAndPopups(browser(), num_tabs, num_popups);
|
| + WaitForTabsAndPopups(browser(), num_tabs, num_popups, 0);
|
| }
|
|
|
| IN_PROC_BROWSER_TEST_F(ExtensionApiTest, WindowOpenPopupLarge) {
|
| @@ -90,7 +104,7 @@ IN_PROC_BROWSER_TEST_F(ExtensionApiTest, WindowOpenPopupLarge) {
|
| const int num_tabs = 0;
|
| const int num_popups = 1;
|
| #endif
|
| - WaitForTabsAndPopups(browser(), num_tabs, num_popups);
|
| + WaitForTabsAndPopups(browser(), num_tabs, num_popups, 0);
|
| }
|
|
|
| IN_PROC_BROWSER_TEST_F(ExtensionApiTest, WindowOpenPopupSmall) {
|
| @@ -102,7 +116,7 @@ IN_PROC_BROWSER_TEST_F(ExtensionApiTest, WindowOpenPopupSmall) {
|
| // On other systems this should open a new popup window.
|
| const int num_tabs = 0;
|
| const int num_popups = 1;
|
| - WaitForTabsAndPopups(browser(), num_tabs, num_popups);
|
| + WaitForTabsAndPopups(browser(), num_tabs, num_popups, 0);
|
| }
|
|
|
| IN_PROC_BROWSER_TEST_F(ExtensionApiTest, PopupBlockingExtension) {
|
| @@ -113,7 +127,7 @@ IN_PROC_BROWSER_TEST_F(ExtensionApiTest, PopupBlockingExtension) {
|
| test_data_dir_.AppendASCII("window_open").AppendASCII("popup_blocking")
|
| .AppendASCII("extension")));
|
|
|
| - WaitForTabsAndPopups(browser(), 5, 3);
|
| + WaitForTabsAndPopups(browser(), 5, 3, 0);
|
| }
|
|
|
| IN_PROC_BROWSER_TEST_F(ExtensionApiTest, PopupBlockingHostedApp) {
|
| @@ -146,7 +160,7 @@ IN_PROC_BROWSER_TEST_F(ExtensionApiTest, PopupBlockingHostedApp) {
|
| browser()->OpenURL(open_popup, GURL(), NEW_FOREGROUND_TAB,
|
| content::PAGE_TRANSITION_TYPED);
|
|
|
| - WaitForTabsAndPopups(browser(), 3, 1);
|
| + WaitForTabsAndPopups(browser(), 3, 1, 0);
|
| }
|
|
|
| IN_PROC_BROWSER_TEST_F(ExtensionApiTest, WindowArgumentsOverflow) {
|
| @@ -175,6 +189,43 @@ IN_PROC_BROWSER_TEST_F(ExtensionApiTest, WindowOpenFocus) {
|
| }
|
| #endif
|
|
|
| +IN_PROC_BROWSER_TEST_F(ExtensionApiTest,
|
| + CloseNonExtensionPanelsOnUninstall) {
|
| + ASSERT_TRUE(StartTestServer());
|
| +
|
| + // Setup listeners to wait on strings we expect the extension pages to send.
|
| + std::vector<std::string> test_strings;
|
| + test_strings.push_back("content_tab");
|
| + test_strings.push_back("content_panel");
|
| + test_strings.push_back("content_popup");
|
| +
|
| + ScopedVector<ExtensionTestMessageListener> listeners;
|
| + for (size_t i = 0; i < test_strings.size(); ++i) {
|
| + listeners.push_back(
|
| + new ExtensionTestMessageListener(test_strings[i], false));
|
| + }
|
| +
|
| + const Extension* extension = LoadExtension(
|
| + test_data_dir_.AppendASCII("window_open").AppendASCII(
|
| + "close_panels_on_uninstall"));
|
| + ASSERT_TRUE(extension);
|
| +
|
| + // Two tabs. One in extension domain and one in non-extension domain.
|
| + // Two popups - one in extension domain and one in non-extension domain.
|
| + // Two panels - one in extension domain and one in non-extension domain.
|
| + WaitForTabsAndPopups(browser(), 2, 2, 2);
|
| +
|
| + // Wait on test messages to make sure the pages loaded.
|
| + for (size_t i = 0; i < listeners.size(); ++i)
|
| + ASSERT_TRUE(listeners[i]->WaitUntilSatisfied());
|
| +
|
| + UninstallExtension(extension->id());
|
| +
|
| + // Wait for one tab and one popup in non-extension domain to stay open.
|
| + // Expect everything else, including panels, to close.
|
| + WaitForTabsAndPopups(browser(), 1, 1, 0);
|
| +}
|
| +
|
| IN_PROC_BROWSER_TEST_F(ExtensionApiTest, WindowOpener) {
|
| ASSERT_TRUE(RunExtensionTest("window_open/opener")) << message_;
|
| }
|
|
|