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

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

Issue 22887021: Pass focus to browser after login. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: . Created 7 years, 4 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
Index: chrome/browser/chromeos/login/login_manager_test.cc
diff --git a/chrome/browser/chromeos/login/login_manager_test.cc b/chrome/browser/chromeos/login/login_manager_test.cc
new file mode 100644
index 0000000000000000000000000000000000000000..6196c832515302d8e66f1d14f58a19366a8de858
--- /dev/null
+++ b/chrome/browser/chromeos/login/login_manager_test.cc
@@ -0,0 +1,68 @@
+// 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.
+
+#include "chrome/browser/chromeos/login/login_manager_test.h"
+
+#include "chrome/browser/browser_process.h"
+#include "chrome/browser/chrome_notification_types.h"
+#include "chrome/browser/chromeos/login/existing_user_controller.h"
+#include "chrome/browser/chromeos/login/user_manager.h"
+#include "chrome/browser/prefs/scoped_user_pref_update.h"
+#include "chrome/common/chrome_switches.h"
+#include "chromeos/chromeos_switches.h"
+#include "content/public/browser/notification_service.h"
+#include "content/public/test/test_utils.h"
+#include "testing/gtest/include/gtest/gtest.h"
+
+namespace chromeos {
+
+LoginManagerTest::LoginManagerTest(bool should_launch_browser)
+ : should_launch_browser_(should_launch_browser) {
+ set_exit_when_last_browser_closes(false);
+}
+
+void LoginManagerTest::SetUpCommandLine(CommandLine* command_line) {
+ command_line->AppendSwitch(chromeos::switches::kLoginManager);
+ command_line->AppendSwitch(chromeos::switches::kForceLoginManagerInTests);
+ command_line->AppendSwitch(::switches::kMultiProfiles);
+}
+
+void LoginManagerTest::SetUpInProcessBrowserTestFixture() {
+ mock_login_utils_ = new testing::NiceMock<MockLoginUtils>();
+ mock_login_utils_->DelegateToFake();
+ mock_login_utils_->GetFakeLoginUtils()->set_should_launch_browser(
+ should_launch_browser_);
+ LoginUtils::Set(mock_login_utils_);
+}
+
+void LoginManagerTest::RegisterUser(const std::string& username) {
+ ListPrefUpdate users_pref(g_browser_process->local_state(), "LoggedInUsers");
+ users_pref->AppendIfNotPresent(new base::StringValue(username));
+}
+
+void LoginManagerTest::SetExpectedCredentials(const std::string& username,
+ const std::string& password) {
+ login_utils().GetFakeLoginUtils()->SetExpectedCredentials(username, password);
+}
+
+bool LoginManagerTest::TryToLogin(const std::string& username,
+ const std::string& password) {
+ ExistingUserController* controller =
+ ExistingUserController::current_controller();
+ EXPECT_TRUE(controller != NULL);
+ controller->Login(UserContext(username, password, std::string()));
+ content::WindowedNotificationObserver(
+ chrome::NOTIFICATION_SESSION_STARTED,
+ content::NotificationService::AllSources()).Wait();
+ if (const User* active_user = UserManager::Get()->GetActiveUser())
+ return active_user->email() == username;
+ return false;
+}
+
+void LoginManagerTest::LoginUser(const std::string& username) {
+ SetExpectedCredentials(username, "password");
+ EXPECT_TRUE(TryToLogin(username, "password"));
+}
+
+} // namespace chromeos
« no previous file with comments | « chrome/browser/chromeos/login/login_manager_test.h ('k') | chrome/browser/chromeos/login/session_login_browsertest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698