summaryrefslogtreecommitdiffstats
path: root/chrome/browser
diff options
context:
space:
mode:
authorben@chromium.org <ben@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-04-02 21:51:20 +0000
committerben@chromium.org <ben@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-04-02 21:51:20 +0000
commit38a8f2d3701767f6c09fc8c3a69765ba32a1d24f (patch)
tree26d1a77a79f3675c29f882cd4f93161b711d4dd5 /chrome/browser
parent9a15771dfe7cafd5117cca97ecbbe3bae742d648 (diff)
downloadchromium_src-38a8f2d3701767f6c09fc8c3a69765ba32a1d24f.zip
chromium_src-38a8f2d3701767f6c09fc8c3a69765ba32a1d24f.tar.gz
chromium_src-38a8f2d3701767f6c09fc8c3a69765ba32a1d24f.tar.bz2
Revert until sequencing issue fixed.
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@13039 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser')
-rw-r--r--chrome/browser/browser.cc36
-rw-r--r--chrome/browser/browser.h2
-rw-r--r--chrome/browser/browser_unittest.cc83
3 files changed, 16 insertions, 105 deletions
diff --git a/chrome/browser/browser.cc b/chrome/browser/browser.cc
index 3359003..d2c3c50 100644
--- a/chrome/browser/browser.cc
+++ b/chrome/browser/browser.cc
@@ -473,26 +473,22 @@ void Browser::OnWindowClosing() {
TabContents* Browser::AddTabWithURL(
const GURL& url, const GURL& referrer, PageTransition::Type transition,
bool foreground, SiteInstance* instance) {
- TabContents* contents = NULL;
- if (type_ == TYPE_NORMAL) {
- GURL url_to_load = url;
- if (url_to_load.is_empty())
- url_to_load = GetHomePage();
- contents = CreateTabContentsForURL(url_to_load, referrer, profile_,
- transition, false, instance);
- tabstrip_model_.AddTabContents(contents, -1, transition, foreground);
- // By default, content believes it is not hidden. When adding contents
- // in the background, tell it that it's hidden.
- if (!foreground)
- contents->WasHidden();
- } else {
- // We're in an app window or a popup window. Find an existing browser to
- // open this URL in, creating one if none exists.
- Browser* b = GetOrCreateTabbedBrowser();
- contents = b->AddTabWithURL(url, referrer, transition, foreground,
- instance);
- b->window()->Show();
- }
+ if ((type_ & TYPE_APP) != 0 && tabstrip_model_.count() == 1) {
+ NOTREACHED() << "Cannot add a tab in a mono tab application.";
+ return NULL;
+ }
+
+ GURL url_to_load = url;
+ if (url_to_load.is_empty())
+ url_to_load = GetHomePage();
+ TabContents* contents =
+ CreateTabContentsForURL(url_to_load, referrer, profile_, transition,
+ false, instance);
+ tabstrip_model_.AddTabContents(contents, -1, transition, foreground);
+ // By default, content believes it is not hidden. When adding contents
+ // in the background, tell it that it's hidden.
+ if (!foreground)
+ contents->WasHidden();
return contents;
}
diff --git a/chrome/browser/browser.h b/chrome/browser/browser.h
index 2013cf9..24f3e05 100644
--- a/chrome/browser/browser.h
+++ b/chrome/browser/browser.h
@@ -571,8 +571,6 @@ class Browser : public TabStripModelDelegate,
// as a key to store window location per application URLs.
static std::wstring ComputeApplicationNameFromURL(const GURL& url);
- FRIEND_TEST(BrowserTest, NoTabsInPopups);
-
// Create a preference dictionary for the provided application name. This is
// done only once per application name / per session.
static void RegisterAppPrefs(const std::wstring& app_name);
diff --git a/chrome/browser/browser_unittest.cc b/chrome/browser/browser_unittest.cc
deleted file mode 100644
index 73a49cd..0000000
--- a/chrome/browser/browser_unittest.cc
+++ /dev/null
@@ -1,83 +0,0 @@
-// Copyright (c) 2009 The Chromium Authors. All rights reserved. Use of this
-// source code is governed by a BSD-style license that can be found in the
-// LICENSE file.
-
-#include "chrome/browser/browser.h"
-#include "chrome/test/in_process_browser_test.h"
-#include "net/base/host_resolver_unittest.h"
-
-class BrowserTest : public InProcessBrowserTest {
- public:
- BrowserTest() {
- host_mapper_ = new net::RuleBasedHostMapper();
- // Avoid making external DNS lookups. In this test we don't need this
- // to succeed.
- host_mapper_->AddSimulatedFailure("*.google.com");
- scoped_host_mapper_.Init(host_mapper_.get());
- }
-
- private:
- scoped_refptr<net::RuleBasedHostMapper> host_mapper_;
- net::ScopedHostMapper scoped_host_mapper_;
-};
-
-// This tests that windows without tabstrips can't have new tabs opened in
-// them.
-IN_PROC_BROWSER_TEST_F(BrowserTest, NoTabsInPopups) {
- Browser::RegisterAppPrefs(L"Test");
-
- // We start with a normal browser with one tab.
- EXPECT_EQ(1, browser()->tab_count());
-
- // Open a popup browser with a single blank foreground tab.
- Browser* popup_browser = browser()->CreateForPopup(browser()->profile());
- popup_browser->AddBlankTab(true);
- EXPECT_EQ(1, popup_browser->tab_count());
-
- // Now try opening another tab in the popup browser.
- popup_browser->AddTabWithURL(GURL("about:blank"), GURL(),
- PageTransition::TYPED, true, NULL);
-
- // The popup should still only have one tab.
- EXPECT_EQ(1, popup_browser->tab_count());
-
- // The normal browser should now have two.
- EXPECT_EQ(2, browser()->tab_count());
-
- // Open an app frame browser with a single blank foreground tab.
- Browser* app_browser =
- browser()->CreateForApp(L"Test", browser()->profile(), false);
- app_browser->AddBlankTab(true);
- EXPECT_EQ(1, app_browser->tab_count());
-
- // Now try opening another tab in the app browser.
- app_browser->AddTabWithURL(GURL("about:blank"), GURL(),
- PageTransition::TYPED, true, NULL);
-
- // The popup should still only have one tab.
- EXPECT_EQ(1, app_browser->tab_count());
-
- // The normal browser should now have three.
- EXPECT_EQ(3, browser()->tab_count());
-
- // Open an app frame popup browser with a single blank foreground tab.
- Browser* app_popup_browser =
- browser()->CreateForApp(L"Test", browser()->profile(), false);
- app_popup_browser->AddBlankTab(true);
- EXPECT_EQ(1, app_popup_browser->tab_count());
-
- // Now try opening another tab in the app popup browser.
- app_popup_browser->AddTabWithURL(GURL("about:blank"), GURL(),
- PageTransition::TYPED, true, NULL);
-
- // The popup should still only have one tab.
- EXPECT_EQ(1, app_popup_browser->tab_count());
-
- // The normal browser should now have four.
- EXPECT_EQ(4, browser()->tab_count());
-
- // Close the additional browsers.
- popup_browser->CloseAllTabs();
- app_browser->CloseAllTabs();
- app_popup_browser->CloseAllTabs();
-}