| Index: chrome/browser/signin/signin_browsertest.cc
 | 
| diff --git a/chrome/browser/signin/signin_browsertest.cc b/chrome/browser/signin/signin_browsertest.cc
 | 
| new file mode 100644
 | 
| index 0000000000000000000000000000000000000000..e3666ce7897b31e79dabe35c159221a4ad5cb86b
 | 
| --- /dev/null
 | 
| +++ b/chrome/browser/signin/signin_browsertest.cc
 | 
| @@ -0,0 +1,107 @@
 | 
| +// Copyright 2013 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.
 | 
| +
 | 
| +#ifndef CHROME_BROWSER_SIGNIN_SIGNIN_BROWSERTEST_H_
 | 
| +#define CHROME_BROWSER_SIGNIN_SIGNIN_BROWSERTEST_H_
 | 
| +
 | 
| +#include "chrome/browser/signin/signin_manager.h"
 | 
| +#include "chrome/browser/signin/signin_manager_factory.h"
 | 
| +#include "chrome/browser/ui/browser.h"
 | 
| +#include "chrome/browser/ui/tabs/tab_strip_model.h"
 | 
| +#include "chrome/browser/ui/webui/signin/login_ui_service.h"
 | 
| +#include "chrome/browser/ui/webui/signin/login_ui_service_factory.h"
 | 
| +#include "chrome/browser/ui/webui/sync_promo/sync_promo_ui.h"
 | 
| +#include "chrome/common/url_constants.h"
 | 
| +#include "chrome/test/base/in_process_browser_test.h"
 | 
| +#include "chrome/test/base/ui_test_utils.h"
 | 
| +#include "content/public/browser/render_process_host.h"
 | 
| +#include "content/public/browser/render_view_host.h"
 | 
| +#include "content/public/browser/web_contents.h"
 | 
| +#include "google_apis/gaia/gaia_urls.h"
 | 
| +#include "net/url_request/test_url_fetcher_factory.h"
 | 
| +
 | 
| +namespace {
 | 
| +  const char kNonSigninURL[] = "www.google.com";
 | 
| +}
 | 
| +
 | 
| +class SigninBrowserTest : public InProcessBrowserTest {
 | 
| + public:
 | 
| +  virtual void SetUp() OVERRIDE {
 | 
| +    factory_.reset(new net::URLFetcherImplFactory());
 | 
| +    fake_factory_.reset(new net::FakeURLFetcherFactory(factory_.get()));
 | 
| +    fake_factory_->SetFakeResponse(
 | 
| +        GaiaUrls::GetInstance()->service_login_url(),
 | 
| +        std::string(),
 | 
| +        true);
 | 
| +    fake_factory_->SetFakeResponse(kNonSigninURL, std::string(), true);
 | 
| +    // Yield control back to the InProcessBrowserTest framework.
 | 
| +    InProcessBrowserTest::SetUp();
 | 
| +  }
 | 
| +
 | 
| +  virtual void TearDown() OVERRIDE {
 | 
| +    if (fake_factory_.get()) {
 | 
| +      fake_factory_->ClearFakeResponses();
 | 
| +      fake_factory_.reset();
 | 
| +    }
 | 
| +
 | 
| +    // Cancel any outstanding URL fetches and destroy the URLFetcherImplFactory
 | 
| +    // we created.
 | 
| +    net::URLFetcher::CancelAll();
 | 
| +    factory_.reset();
 | 
| +    InProcessBrowserTest::TearDown();
 | 
| +  }
 | 
| +
 | 
| + private:
 | 
| +  // Fake URLFetcher factory used to mock out GAIA signin.
 | 
| +  scoped_ptr<net::FakeURLFetcherFactory> fake_factory_;
 | 
| +
 | 
| +  // The URLFetcherImplFactory instance used to instantiate |fake_factory_|.
 | 
| +  scoped_ptr<net::URLFetcherImplFactory> factory_;
 | 
| +};
 | 
| +
 | 
| +IN_PROC_BROWSER_TEST_F(SigninBrowserTest, ProcessIsolation) {
 | 
| +  // If the one-click-signin feature is not enabled (e.g Chrome OS), we
 | 
| +  // never grant signin privileges to any renderer processes.
 | 
| +  const bool kOneClickSigninEnabled = SyncPromoUI::UseWebBasedSigninFlow();
 | 
| +
 | 
| +  SigninManager* signin = SigninManagerFactory::GetForProfile(
 | 
| +      browser()->profile());
 | 
| +  EXPECT_FALSE(signin->HasSigninProcess());
 | 
| +
 | 
| +  ui_test_utils::NavigateToURL(browser(), SyncPromoUI::GetSyncPromoURL(
 | 
| +      GURL(), SyncPromoUI::SOURCE_NTP_LINK, true));
 | 
| +  EXPECT_EQ(kOneClickSigninEnabled, signin->HasSigninProcess());
 | 
| +
 | 
| +  // Navigating away should change the process.
 | 
| +  ui_test_utils::NavigateToURL(browser(), GURL(chrome::kChromeUINewTabURL));
 | 
| +  EXPECT_FALSE(signin->HasSigninProcess());
 | 
| +
 | 
| +  ui_test_utils::NavigateToURL(browser(), SyncPromoUI::GetSyncPromoURL(
 | 
| +      GURL(), SyncPromoUI::SOURCE_NTP_LINK, true));
 | 
| +  EXPECT_EQ(kOneClickSigninEnabled, signin->HasSigninProcess());
 | 
| +
 | 
| +  content::WebContents* active_tab =
 | 
| +      browser()->tab_strip_model()->GetActiveWebContents();
 | 
| +  int active_tab_process_id =
 | 
| +      active_tab->GetRenderProcessHost()->GetID();
 | 
| +  EXPECT_EQ(kOneClickSigninEnabled,
 | 
| +            signin->IsSigninProcess(active_tab_process_id));
 | 
| +  EXPECT_EQ(0, active_tab->GetRenderViewHost()->GetEnabledBindings());
 | 
| +
 | 
| +  // Entry points to signin request "SINGLETON_TAB" mode, so a new request
 | 
| +  // shouldn't change anything.
 | 
| +  LoginUIService* login = LoginUIServiceFactory::GetForProfile(
 | 
| +      browser()->profile());
 | 
| +  login->ShowLoginPopup();
 | 
| +  EXPECT_EQ(active_tab, browser()->tab_strip_model()->GetActiveWebContents());
 | 
| +  EXPECT_EQ(kOneClickSigninEnabled,
 | 
| +            signin->IsSigninProcess(active_tab_process_id));
 | 
| +
 | 
| +  // Navigating away should change the process.
 | 
| +  ui_test_utils::NavigateToURL(browser(), GURL(kNonSigninURL));
 | 
| +  EXPECT_FALSE(signin->IsSigninProcess(
 | 
| +      active_tab->GetRenderProcessHost()->GetID()));
 | 
| +}
 | 
| +
 | 
| +#endif  // CHROME_BROWSER_SIGNIN_SIGNIN_BROWSERTEST_H_
 | 
| 
 |