| Index: chrome/browser/login_prompt_uitest.cc
|
| ===================================================================
|
| --- chrome/browser/login_prompt_uitest.cc (revision 68044)
|
| +++ chrome/browser/login_prompt_uitest.cc (working copy)
|
| @@ -1,280 +0,0 @@
|
| -// Copyright (c) 2006-2008 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 <string>
|
| -
|
| -#include "chrome/browser/net/url_fixer_upper.h"
|
| -#include "chrome/common/chrome_switches.h"
|
| -#include "chrome/common/url_constants.h"
|
| -#include "chrome/test/automation/tab_proxy.h"
|
| -#include "chrome/test/automation/browser_proxy.h"
|
| -#include "chrome/test/ui/ui_test.h"
|
| -#include "net/test/test_server.h"
|
| -
|
| -using std::wstring;
|
| -
|
| -namespace {
|
| -
|
| -const FilePath::CharType kDocRoot[] = FILE_PATH_LITERAL("chrome/test/data");
|
| -
|
| -} // namespace
|
| -
|
| -class LoginPromptTest : public UITest {
|
| - protected:
|
| - LoginPromptTest()
|
| - : username_basic_(L"basicuser"),
|
| - username_digest_(L"digestuser"),
|
| - password_(L"secret"),
|
| - password_bad_(L"denyme"),
|
| - test_server_(net::TestServer::TYPE_HTTP, FilePath(kDocRoot)) {
|
| - }
|
| -
|
| - void AppendTab(const GURL& url) {
|
| - scoped_refptr<BrowserProxy> window_proxy(automation()->GetBrowserWindow(0));
|
| - ASSERT_TRUE(window_proxy.get());
|
| - ASSERT_TRUE(window_proxy->AppendTab(url));
|
| - }
|
| -
|
| - protected:
|
| - wstring username_basic_;
|
| - wstring username_digest_;
|
| - wstring password_;
|
| - wstring password_bad_;
|
| -
|
| - net::TestServer test_server_;
|
| -};
|
| -
|
| -wstring ExpectedTitleFromAuth(const wstring& username,
|
| - const wstring& password) {
|
| - // The TestServer sets the title to username/password on successful login.
|
| - return username + L"/" + password;
|
| -}
|
| -
|
| -#if defined(OS_WIN)
|
| -// Probably related to test server flakiness in http://crbug.com/60937
|
| -#define MAYBE_TestBasicAuth FLAKY_TestBasicAuth
|
| -#else
|
| -#define MAYBE_TestBasicAuth TestBasicAuth
|
| -#endif
|
| -
|
| -// Test that "Basic" HTTP authentication works.
|
| -TEST_F(LoginPromptTest, MAYBE_TestBasicAuth) {
|
| - ASSERT_TRUE(test_server_.Start());
|
| -
|
| - scoped_refptr<TabProxy> tab(GetActiveTab());
|
| - ASSERT_TRUE(tab.get());
|
| - ASSERT_EQ(AUTOMATION_MSG_NAVIGATION_AUTH_NEEDED,
|
| - tab->NavigateToURL(test_server_.GetURL("auth-basic")));
|
| -
|
| - EXPECT_TRUE(tab->NeedsAuth());
|
| - EXPECT_FALSE(tab->SetAuth(username_basic_, password_bad_));
|
| - EXPECT_TRUE(tab->NeedsAuth());
|
| - EXPECT_TRUE(tab->CancelAuth());
|
| - EXPECT_EQ(L"Denied: wrong password", GetActiveTabTitle());
|
| -
|
| - ASSERT_EQ(AUTOMATION_MSG_NAVIGATION_AUTH_NEEDED,
|
| - tab->NavigateToURL(test_server_.GetURL("auth-basic")));
|
| -
|
| - EXPECT_TRUE(tab->NeedsAuth());
|
| - EXPECT_TRUE(tab->SetAuth(username_basic_, password_));
|
| - EXPECT_EQ(ExpectedTitleFromAuth(username_basic_, password_),
|
| - GetActiveTabTitle());
|
| -}
|
| -
|
| -#if defined(OS_WIN)
|
| -// Probably related to test server flakiness in http://crbug.com/60937
|
| -#define MAYBE_TestDigestAuth FLAKY_TestDigestAuth
|
| -#else
|
| -#define MAYBE_TestDigestAuth TestDigestAuth
|
| -#endif
|
| -
|
| -// Test that "Digest" HTTP authentication works.
|
| -TEST_F(LoginPromptTest, MAYBE_TestDigestAuth) {
|
| - ASSERT_TRUE(test_server_.Start());
|
| -
|
| - scoped_refptr<TabProxy> tab(GetActiveTab());
|
| - ASSERT_TRUE(tab.get());
|
| - ASSERT_EQ(AUTOMATION_MSG_NAVIGATION_AUTH_NEEDED,
|
| - tab->NavigateToURL(test_server_.GetURL("auth-digest")));
|
| -
|
| - EXPECT_TRUE(tab->NeedsAuth());
|
| - EXPECT_FALSE(tab->SetAuth(username_digest_, password_bad_));
|
| - EXPECT_TRUE(tab->CancelAuth());
|
| - EXPECT_EQ(L"Denied: wrong password", GetActiveTabTitle());
|
| -
|
| - ASSERT_EQ(AUTOMATION_MSG_NAVIGATION_AUTH_NEEDED,
|
| - tab->NavigateToURL(test_server_.GetURL("auth-digest")));
|
| -
|
| - EXPECT_TRUE(tab->NeedsAuth());
|
| - EXPECT_TRUE(tab->SetAuth(username_digest_, password_));
|
| - EXPECT_EQ(ExpectedTitleFromAuth(username_digest_, password_),
|
| - GetActiveTabTitle());
|
| -}
|
| -
|
| -#if defined(OS_WIN)
|
| -// Probably related to test server flakiness in http://crbug.com/60937
|
| -#define MAYBE_TestTwoAuths FLAKY_TestTwoAuths
|
| -#else
|
| -#define MAYBE_TestTwoAuths TestTwoAuths
|
| -#endif
|
| -
|
| -// Test that logging in on 2 tabs at once works.
|
| -TEST_F(LoginPromptTest, MAYBE_TestTwoAuths) {
|
| - ASSERT_TRUE(test_server_.Start());
|
| -
|
| - scoped_refptr<TabProxy> basic_tab(GetActiveTab());
|
| - ASSERT_TRUE(basic_tab.get());
|
| - ASSERT_EQ(AUTOMATION_MSG_NAVIGATION_AUTH_NEEDED,
|
| - basic_tab->NavigateToURL(test_server_.GetURL("auth-basic")));
|
| -
|
| - AppendTab(GURL(chrome::kAboutBlankURL));
|
| - scoped_refptr<TabProxy> digest_tab(GetActiveTab());
|
| - ASSERT_TRUE(digest_tab.get());
|
| - ASSERT_EQ(AUTOMATION_MSG_NAVIGATION_AUTH_NEEDED,
|
| - digest_tab->NavigateToURL(test_server_.GetURL("auth-digest")));
|
| -
|
| - EXPECT_TRUE(basic_tab->NeedsAuth());
|
| - EXPECT_TRUE(basic_tab->SetAuth(username_basic_, password_));
|
| - EXPECT_TRUE(digest_tab->NeedsAuth());
|
| - EXPECT_TRUE(digest_tab->SetAuth(username_digest_, password_));
|
| -
|
| - wstring title;
|
| - EXPECT_TRUE(basic_tab->GetTabTitle(&title));
|
| - EXPECT_EQ(ExpectedTitleFromAuth(username_basic_, password_), title);
|
| -
|
| - EXPECT_TRUE(digest_tab->GetTabTitle(&title));
|
| - EXPECT_EQ(ExpectedTitleFromAuth(username_digest_, password_), title);
|
| -}
|
| -
|
| -#if defined(OS_WIN)
|
| -// Probably related to test server flakiness in http://crbug.com/60937
|
| -#define MAYBE_TestCancelAuth FLAKY_TestCancelAuth
|
| -#else
|
| -#define MAYBE_TestCancelAuth TestCancelAuth
|
| -#endif
|
| -
|
| -// Test that cancelling authentication works.
|
| -TEST_F(LoginPromptTest, MAYBE_TestCancelAuth) {
|
| - ASSERT_TRUE(test_server_.Start());
|
| -
|
| - scoped_refptr<TabProxy> tab(GetActiveTab());
|
| - ASSERT_TRUE(tab.get());
|
| -
|
| - // First navigate to a test server page so we have something to go back to.
|
| - ASSERT_EQ(AUTOMATION_MSG_NAVIGATION_SUCCESS,
|
| - tab->NavigateToURL(test_server_.GetURL("a")));
|
| -
|
| - // Navigating while auth is requested is the same as cancelling.
|
| - ASSERT_EQ(AUTOMATION_MSG_NAVIGATION_AUTH_NEEDED,
|
| - tab->NavigateToURL(test_server_.GetURL("auth-basic")));
|
| - EXPECT_TRUE(tab->NeedsAuth());
|
| - ASSERT_EQ(AUTOMATION_MSG_NAVIGATION_SUCCESS,
|
| - tab->NavigateToURL(test_server_.GetURL("b")));
|
| - EXPECT_FALSE(tab->NeedsAuth());
|
| -
|
| - ASSERT_EQ(AUTOMATION_MSG_NAVIGATION_AUTH_NEEDED,
|
| - tab->NavigateToURL(test_server_.GetURL("auth-basic")));
|
| - EXPECT_TRUE(tab->NeedsAuth());
|
| - EXPECT_TRUE(tab->GoBack()); // should bring us back to 'a'
|
| - EXPECT_FALSE(tab->NeedsAuth());
|
| -
|
| - // Now add a page and go back, so we have something to go forward to.
|
| - ASSERT_EQ(AUTOMATION_MSG_NAVIGATION_SUCCESS,
|
| - tab->NavigateToURL(test_server_.GetURL("c")));
|
| - EXPECT_TRUE(tab->GoBack()); // should bring us back to 'a'
|
| -
|
| - ASSERT_EQ(AUTOMATION_MSG_NAVIGATION_AUTH_NEEDED,
|
| - tab->NavigateToURL(test_server_.GetURL("auth-basic")));
|
| - EXPECT_TRUE(tab->NeedsAuth());
|
| - EXPECT_TRUE(tab->GoForward()); // should bring us to 'c'
|
| - EXPECT_FALSE(tab->NeedsAuth());
|
| -
|
| - // Now test that cancelling works as expected.
|
| - ASSERT_EQ(AUTOMATION_MSG_NAVIGATION_AUTH_NEEDED,
|
| - tab->NavigateToURL(test_server_.GetURL("auth-basic")));
|
| - EXPECT_TRUE(tab->NeedsAuth());
|
| - EXPECT_TRUE(tab->CancelAuth());
|
| - EXPECT_FALSE(tab->NeedsAuth());
|
| - EXPECT_EQ(L"Denied: no auth", GetActiveTabTitle());
|
| -}
|
| -
|
| -#if defined(OS_WIN)
|
| -// Probably related to test server flakiness in http://crbug.com/60937
|
| -#define MAYBE_SupplyRedundantAuths FLAKY_SupplyRedundantAuths
|
| -#else
|
| -#define MAYBE_SupplyRedundantAuths SupplyRedundantAuths
|
| -#endif
|
| -
|
| -// If multiple tabs are looking for the same auth, the user should only have to
|
| -// enter it once.
|
| -TEST_F(LoginPromptTest, MAYBE_SupplyRedundantAuths) {
|
| - ASSERT_TRUE(test_server_.Start());
|
| -
|
| - scoped_refptr<TabProxy> basic_tab1(GetActiveTab());
|
| - ASSERT_TRUE(basic_tab1.get());
|
| - ASSERT_EQ(AUTOMATION_MSG_NAVIGATION_AUTH_NEEDED,
|
| - basic_tab1->NavigateToURL(test_server_.GetURL("auth-basic/1")));
|
| - EXPECT_TRUE(basic_tab1->NeedsAuth());
|
| -
|
| - AppendTab(GURL(chrome::kAboutBlankURL));
|
| - scoped_refptr<TabProxy> basic_tab2(GetActiveTab());
|
| - ASSERT_TRUE(basic_tab2.get());
|
| - ASSERT_EQ(AUTOMATION_MSG_NAVIGATION_AUTH_NEEDED,
|
| - basic_tab2->NavigateToURL(test_server_.GetURL("auth-basic/2")));
|
| - EXPECT_TRUE(basic_tab2->NeedsAuth());
|
| -
|
| - // Set the auth in only one of the tabs (but wait for the other to load).
|
| - int64 last_navigation_time;
|
| - ASSERT_TRUE(basic_tab2->GetLastNavigationTime(&last_navigation_time));
|
| - EXPECT_TRUE(basic_tab1->SetAuth(username_basic_, password_));
|
| - EXPECT_TRUE(basic_tab2->WaitForNavigation(last_navigation_time));
|
| -
|
| - // Now both tabs have loaded.
|
| - wstring title1;
|
| - EXPECT_TRUE(basic_tab1->GetTabTitle(&title1));
|
| - EXPECT_EQ(ExpectedTitleFromAuth(username_basic_, password_), title1);
|
| - wstring title2;
|
| - EXPECT_TRUE(basic_tab2->GetTabTitle(&title2));
|
| - EXPECT_EQ(ExpectedTitleFromAuth(username_basic_, password_), title2);
|
| -}
|
| -
|
| -#if defined(OS_WIN)
|
| -// Probably related to test server flakiness in http://crbug.com/60937
|
| -#define MAYBE_CancelRedundantAuths FLAKY_CancelRedundantAuths
|
| -#else
|
| -#define MAYBE_CancelRedundantAuths CancelRedundantAuths
|
| -#endif
|
| -
|
| -// If multiple tabs are looking for the same auth, and one is cancelled, the
|
| -// other should be cancelled as well.
|
| -TEST_F(LoginPromptTest, MAYBE_CancelRedundantAuths) {
|
| - ASSERT_TRUE(test_server_.Start());
|
| -
|
| - scoped_refptr<TabProxy> basic_tab1(GetActiveTab());
|
| - ASSERT_TRUE(basic_tab1.get());
|
| - ASSERT_EQ(AUTOMATION_MSG_NAVIGATION_AUTH_NEEDED,
|
| - basic_tab1->NavigateToURL(test_server_.GetURL("auth-basic/1")));
|
| - EXPECT_TRUE(basic_tab1->NeedsAuth());
|
| -
|
| - AppendTab(GURL(chrome::kAboutBlankURL));
|
| - scoped_refptr<TabProxy> basic_tab2(GetActiveTab());
|
| - ASSERT_TRUE(basic_tab2.get());
|
| - ASSERT_EQ(AUTOMATION_MSG_NAVIGATION_AUTH_NEEDED,
|
| - basic_tab2->NavigateToURL(test_server_.GetURL("auth-basic/2")));
|
| - EXPECT_TRUE(basic_tab2->NeedsAuth());
|
| -
|
| - // Cancel the auth in only one of the tabs (but wait for the other to load).
|
| - int64 last_navigation_time;
|
| - ASSERT_TRUE(basic_tab2->GetLastNavigationTime(&last_navigation_time));
|
| - EXPECT_TRUE(basic_tab1->CancelAuth());
|
| - EXPECT_TRUE(basic_tab2->WaitForNavigation(last_navigation_time));
|
| -
|
| - // Now both tabs have been denied.
|
| - wstring title1;
|
| - EXPECT_TRUE(basic_tab1->GetTabTitle(&title1));
|
| - EXPECT_EQ(L"Denied: no auth", title1);
|
| - wstring title2;
|
| - EXPECT_TRUE(basic_tab2->GetTabTitle(&title2));
|
| - EXPECT_EQ(L"Denied: no auth", title2);
|
| -}
|
|
|