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

Unified Diff: chrome/browser/chromeos/login/login_manager_view_browsertest.cc

Issue 1256004: In process browser test for login screen. (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: '' Created 10 years, 9 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 | « chrome/browser/chromeos/login/login_manager_view.cc ('k') | chrome/browser/chromeos/login/login_utils.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/chromeos/login/login_manager_view_browsertest.cc
===================================================================
--- chrome/browser/chromeos/login/login_manager_view_browsertest.cc (revision 0)
+++ chrome/browser/chromeos/login/login_manager_view_browsertest.cc (revision 0)
@@ -0,0 +1,139 @@
+// Copyright (c) 2010 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 "base/message_loop.h"
+#include "chrome/browser/chromeos/cros/mock_cryptohome_library.h"
+#include "chrome/browser/chromeos/cros/cros_in_process_browser_test.h"
+#include "chrome/browser/chromeos/cros/mock_login_library.h"
+#include "chrome/browser/chromeos/login/login_manager_view.h"
+#include "chrome/browser/chromeos/login/login_utils.h"
+#include "chrome/browser/chromeos/login/wizard_controller.h"
+#include "chrome/browser/chromeos/login/wizard_screen.h"
+#include "chrome/common/chrome_switches.h"
+#include "testing/gtest/include/gtest/gtest.h"
+#include "testing/gmock/include/gmock/gmock.h"
+
+namespace chromeos {
+
+using ::testing::AnyNumber;
+using ::testing::Return;
+
+const char kUsername[] = "test_user@gmail.com";
+const char kPassword[] = "test_password";
+
+class MockAuthenticator : public Authenticator {
+ public:
+ explicit MockAuthenticator(LoginStatusConsumer* consumer,
+ const std::string& expected_username,
+ const std::string& expected_password)
+ : Authenticator(consumer),
+ expected_username_(expected_username),
+ expected_password_(expected_password) {
+ }
+
+ // Returns true after calling OnLoginSuccess().
+ virtual bool Authenticate(const std::string& username,
+ const std::string& password) {
+ EXPECT_EQ(expected_username_, username);
+ EXPECT_EQ(expected_password_, password);
+ consumer_->OnLoginSuccess(username, std::vector<std::string>());
+ return true;
+ }
+
+ private:
+ std::string expected_username_;
+ std::string expected_password_;
+
+ DISALLOW_COPY_AND_ASSIGN(MockAuthenticator);
+};
+
+class MockLoginUtils : public LoginUtils {
+ public:
+ explicit MockLoginUtils(const std::string& expected_username,
+ const std::string& expected_password)
+ : expected_username_(expected_username),
+ expected_password_(expected_password) {
+ }
+
+ virtual void CompleteLogin(const std::string& username,
+ std::vector<std::string> cookies) {
+ EXPECT_EQ(expected_username_, username);
+ }
+
+ virtual Authenticator* CreateAuthenticator(LoginStatusConsumer* consumer) {
+ return new MockAuthenticator(
+ consumer, expected_username_, expected_password_);
+ }
+
+ private:
+ std::string expected_username_;
+ std::string expected_password_;
+
+ DISALLOW_COPY_AND_ASSIGN(MockLoginUtils);
+};
+
+class LoginManagerViewTest : public CrosInProcessBrowserTest {
+ public:
+ LoginManagerViewTest() {
+ }
+
+ protected:
+ virtual void SetUpCommandLine(CommandLine* command_line) {
+ command_line->AppendSwitch(switches::kLoginManager);
+ command_line->AppendSwitchWithValue(switches::kLoginScreen,
+ WizardController::kLoginScreenName);
+ }
+
+ virtual Browser* CreateBrowser(Profile* profile) {
+ // Don't need to create separate browser window for OOBE wizard.
+ return NULL;
+ }
+
+ virtual void SetUpInProcessBrowserTestFixture() {
+ CrosInProcessBrowserTest::SetUpInProcessBrowserTestFixture();
+
+ chromeos::CrosLibrary::TestApi* test_api =
+ chromeos::CrosLibrary::Get()->GetTestApi();
+ mock_login_library_ = new MockLoginLibrary();
+ EXPECT_CALL(*mock_login_library_, EmitLoginPromptReady())
+ .Times(1);
+ test_api->SetLoginLibrary(mock_login_library_);
+
+ mock_cryptohome_library_ = new MockCryptohomeLibrary();
+ EXPECT_CALL(*mock_cryptohome_library_, IsMounted())
+ .Times(AnyNumber())
+ .WillRepeatedly((Return(true)));
+ test_api->SetCryptohomeLibrary(mock_cryptohome_library_);
+
+ LoginUtils::Set(new MockLoginUtils(kUsername, kPassword));
+ }
+
+ virtual void TearDownInProcessBrowserTestFixture() {
+ CrosInProcessBrowserTest::TearDownInProcessBrowserTestFixture();
+ chromeos::CrosLibrary::TestApi* test_api =
+ chromeos::CrosLibrary::Get()->GetTestApi();
+ test_api->SetLoginLibrary(NULL);
+ }
+
+ private:
+ MockLoginLibrary* mock_login_library_;
+ MockCryptohomeLibrary* mock_cryptohome_library_;
+
+ DISALLOW_COPY_AND_ASSIGN(LoginManagerViewTest);
+};
+
+IN_PROC_BROWSER_TEST_F(LoginManagerViewTest, TestBasic) {
+ WizardController* controller = WizardController::default_controller();
+ ASSERT_TRUE(controller != NULL);
+ ASSERT_EQ(controller->current_screen(), controller->GetLoginScreen());
+ LoginManagerView* login = controller->GetLoginScreen()->view();
+ login->SetUsername(kUsername);
+ login->SetPassword(kPassword);
+ login->Login();
+
+ // End the message loop to quit the test.
+ MessageLoop::current()->Quit();
+}
+
+} // namespace chromeos
Property changes on: chrome/browser/chromeos/login/login_manager_view_browsertest.cc
___________________________________________________________________
Added: svn:eol-style
+ LF
« no previous file with comments | « chrome/browser/chromeos/login/login_manager_view.cc ('k') | chrome/browser/chromeos/login/login_utils.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698