summaryrefslogtreecommitdiffstats
path: root/chrome/browser
diff options
context:
space:
mode:
authorjcampan@chromium.org <jcampan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2008-09-11 15:48:56 +0000
committerjcampan@chromium.org <jcampan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2008-09-11 15:48:56 +0000
commitd08cd21d05e71fba90efdaacd45771e266730b19 (patch)
tree08ff048ba3759af9d013b2ce9a30d17e4907e554 /chrome/browser
parentd8e41ed4a55e60be60d47de5bbcb8a027e85a879 (diff)
downloadchromium_src-d08cd21d05e71fba90efdaacd45771e266730b19.zip
chromium_src-d08cd21d05e71fba90efdaacd45771e266730b19.tar.gz
chromium_src-d08cd21d05e71fba90efdaacd45771e266730b19.tar.bz2
Closing a tab with a constrained pop-up showing an SSL interstitial would crash the browser.
BUG=1966 TEST=Open a page that opens a popup which is served over bad SSL. Close the tab. Review URL: http://codereview.chromium.org/1898 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@2058 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser')
-rw-r--r--chrome/browser/ssl_blocking_page.cc5
-rw-r--r--chrome/browser/ssl_uitest.cc31
2 files changed, 33 insertions, 3 deletions
diff --git a/chrome/browser/ssl_blocking_page.cc b/chrome/browser/ssl_blocking_page.cc
index a8f5152..699c9e2 100644
--- a/chrome/browser/ssl_blocking_page.cc
+++ b/chrome/browser/ssl_blocking_page.cc
@@ -171,7 +171,10 @@ void SSLBlockingPage::Observe(NotificationType type,
// the last entry is kept for the restoring on next start-up.
Browser* browser = Browser::GetBrowserForController(tab_->controller(),
NULL);
- if (remove_last_entry_ &&
+ // We may not have a browser (this is the case for constrained popups), in
+ // which case it does not matter if we do not remove the temporary entry
+ // as their navigation history is not saved.
+ if (remove_last_entry_ && browser &&
!browser->tabstrip_model()->closing_all()) {
tab_->controller()->RemoveLastEntry();
}
diff --git a/chrome/browser/ssl_uitest.cc b/chrome/browser/ssl_uitest.cc
index 93a7015..7b34292 100644
--- a/chrome/browser/ssl_uitest.cc
+++ b/chrome/browser/ssl_uitest.cc
@@ -123,13 +123,13 @@ TEST_F(SSLUITest, TestHTTP) {
// Visits a page over http which includes broken https resources (status should
// be OK).
TEST_F(SSLUITest, TestHTTPWithBrokenHTTPSResource) {
- TestServer httpServer(kDocRoot);
+ TestServer http_server(kDocRoot);
HTTPSTestServer httpsServer(kHostName, kBadHTTPSPort,
kDocRoot, GetExpiredCertPath());
scoped_ptr<TabProxy> tab(GetActiveTabProxy());
NavigateTab(tab.get(),
- httpServer.TestServerPageW(L"files/ssl/page_with_unsafe_contents.html"));
+ http_server.TestServerPageW(L"files/ssl/page_with_unsafe_contents.html"));
SecurityStyle security_style;
int cert_status;
@@ -470,6 +470,33 @@ TEST_F(SSLUITest, TestRefNavigation) {
EXPECT_EQ(NavigationEntry::SSLStatus::NORMAL_CONTENT, mixed_content_state);
}
+// Tests that closing a page that has a unsafe pop-up does not crash the browser
+// (bug #1966).
+TEST_F(SSLUITest, TestCloseTabWithUnsafePopup) {
+ TestServer http_server(kDocRoot);
+ HTTPSTestServer bad_https_server(kHostName, kBadHTTPSPort,
+ kDocRoot, GetExpiredCertPath());
+
+ scoped_ptr<TabProxy> tab(GetActiveTabProxy());
+ NavigateTab(tab.get(),
+ http_server.TestServerPageW(
+ L"files/ssl/page_with_unsafe_popup.html"));
+
+ int popup_count = 0;
+ EXPECT_TRUE(tab->GetConstrainedWindowCount(&popup_count));
+ EXPECT_EQ(1, popup_count);
+
+ // Let's add another tab to make sure the browser does not exit when we close
+ // the first tab.
+ scoped_ptr<BrowserProxy> browser_proxy(automation()->GetBrowserWindow(0));
+ EXPECT_TRUE(browser_proxy.get());
+ browser_proxy->AppendTab(
+ http_server.TestServerPageW(L"files/ssl/google.html"));
+
+ // Close the first tab.
+ tab->Close();
+}
+
// TODO (jcampan): more tests to do below.
// Visit a page over bad https that is a redirect to a page with good https.