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

Unified Diff: chrome/browser/extensions/window_open_apitest.cc

Issue 8387010: Close all panels originated by the extension when extension unloads. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Code review feedback. Created 9 years, 2 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | chrome/browser/ui/browser.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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_;
}
« no previous file with comments | « no previous file | chrome/browser/ui/browser.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698