| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "ash/shell.h" |
| 6 #include "ash/wm/user_activity_detector.h" |
| 5 #include "base/bind.h" | 7 #include "base/bind.h" |
| 6 #include "base/command_line.h" | 8 #include "base/command_line.h" |
| 7 #include "base/compiler_specific.h" | 9 #include "base/compiler_specific.h" |
| 8 #include "base/memory/scoped_ptr.h" | 10 #include "base/memory/scoped_ptr.h" |
| 11 #include "base/path_service.h" |
| 12 #include "base/stl_util.h" |
| 9 #include "chrome/browser/chromeos/cros/cros_in_process_browser_test.h" | 13 #include "chrome/browser/chromeos/cros/cros_in_process_browser_test.h" |
| 10 #include "chrome/browser/chromeos/cros/cros_mock.h" | 14 #include "chrome/browser/chromeos/cros/cros_mock.h" |
| 11 #include "chrome/browser/chromeos/cros/mock_network_library.h" | 15 #include "chrome/browser/chromeos/cros/mock_network_library.h" |
| 12 #include "chrome/browser/chromeos/login/existing_user_controller.h" | 16 #include "chrome/browser/chromeos/login/existing_user_controller.h" |
| 13 #include "chrome/browser/chromeos/login/helper.h" | 17 #include "chrome/browser/chromeos/login/helper.h" |
| 14 #include "chrome/browser/chromeos/login/login_display.h" | 18 #include "chrome/browser/chromeos/login/login_display.h" |
| 15 #include "chrome/browser/chromeos/login/login_display_host.h" | 19 #include "chrome/browser/chromeos/login/login_display_host.h" |
| 16 #include "chrome/browser/chromeos/login/login_performer.h" | 20 #include "chrome/browser/chromeos/login/login_performer.h" |
| 17 #include "chrome/browser/chromeos/login/login_status_consumer.h" | 21 #include "chrome/browser/chromeos/login/login_status_consumer.h" |
| 18 #include "chrome/browser/chromeos/login/login_utils.h" | 22 #include "chrome/browser/chromeos/login/login_utils.h" |
| 19 #include "chrome/browser/chromeos/login/mock_authenticator.h" | 23 #include "chrome/browser/chromeos/login/mock_authenticator.h" |
| 20 #include "chrome/browser/chromeos/login/mock_login_utils.h" | 24 #include "chrome/browser/chromeos/login/mock_login_utils.h" |
| 21 #include "chrome/browser/chromeos/login/mock_url_fetchers.h" | 25 #include "chrome/browser/chromeos/login/mock_url_fetchers.h" |
| 22 #include "chrome/browser/chromeos/login/mock_user_manager.h" | 26 #include "chrome/browser/chromeos/login/mock_user_manager.h" |
| 23 #include "chrome/browser/chromeos/login/wizard_controller.h" | 27 #include "chrome/browser/chromeos/login/wizard_controller.h" |
| 28 #include "chrome/browser/chromeos/settings/cros_settings.h" |
| 29 #include "chrome/browser/policy/browser_policy_connector.h" |
| 30 #include "chrome/browser/policy/cloud_policy_constants.h" |
| 31 #include "chrome/browser/policy/cloud_policy_store.h" |
| 32 #include "chrome/browser/policy/device_local_account_policy_service.h" |
| 33 #include "chrome/browser/policy/policy_builder.h" |
| 34 #include "chrome/browser/policy/proto/chrome_device_policy.pb.h" |
| 35 #include "chrome/common/chrome_notification_types.h" |
| 36 #include "chrome/common/chrome_paths.h" |
| 24 #include "chrome/common/chrome_switches.h" | 37 #include "chrome/common/chrome_switches.h" |
| 38 #include "chrome/test/base/testing_browser_process.h" |
| 25 #include "chrome/test/base/testing_profile.h" | 39 #include "chrome/test/base/testing_profile.h" |
| 26 #include "chrome/test/base/ui_test_utils.h" | 40 #include "chrome/test/base/ui_test_utils.h" |
| 41 #include "chromeos/dbus/fake_session_manager_client.h" |
| 27 #include "chromeos/dbus/mock_dbus_thread_manager.h" | 42 #include "chromeos/dbus/mock_dbus_thread_manager.h" |
| 28 #include "chromeos/dbus/mock_session_manager_client.h" | 43 #include "chromeos/dbus/mock_session_manager_client.h" |
| 29 #include "chromeos/dbus/mock_shill_manager_client.h" | 44 #include "chromeos/dbus/mock_shill_manager_client.h" |
| 45 #include "content/public/browser/notification_watcher.h" |
| 46 #include "content/public/test/mock_notification_observer.h" |
| 30 #include "google_apis/gaia/mock_url_fetcher_factory.h" | 47 #include "google_apis/gaia/mock_url_fetcher_factory.h" |
| 31 #include "grit/generated_resources.h" | 48 #include "grit/generated_resources.h" |
| 32 #include "testing/gmock/include/gmock/gmock.h" | 49 #include "testing/gmock/include/gmock/gmock.h" |
| 33 #include "testing/gtest/include/gtest/gtest.h" | 50 #include "testing/gtest/include/gtest/gtest.h" |
| 34 #include "ui/base/l10n/l10n_util.h" | 51 #include "ui/base/l10n/l10n_util.h" |
| 35 | 52 |
| 36 using ::testing::_; | 53 using ::testing::_; |
| 37 using ::testing::AnyNumber; | 54 using ::testing::AnyNumber; |
| 38 using ::testing::AnyOf; | 55 using ::testing::AnyOf; |
| 39 using ::testing::Invoke; | 56 using ::testing::Invoke; |
| 40 using ::testing::InvokeWithoutArgs; | 57 using ::testing::InvokeWithoutArgs; |
| 41 using ::testing::Return; | 58 using ::testing::Return; |
| 59 using ::testing::ReturnRef; |
| 42 using ::testing::ReturnNull; | 60 using ::testing::ReturnNull; |
| 43 using ::testing::Sequence; | 61 using ::testing::Sequence; |
| 44 using ::testing::WithArg; | 62 using ::testing::WithArg; |
| 45 | 63 |
| 64 namespace em = enterprise_management; |
| 65 |
| 46 namespace chromeos { | 66 namespace chromeos { |
| 47 | 67 |
| 48 namespace { | 68 namespace { |
| 49 | 69 |
| 50 const char kUsername[] = "test_user@gmail.com"; | 70 const char kUsername[] = "test_user@gmail.com"; |
| 51 const char kNewUsername[] = "test_new_user@gmail.com"; | 71 const char kNewUsername[] = "test_new_user@gmail.com"; |
| 52 const char kPassword[] = "test_password"; | 72 const char kPassword[] = "test_password"; |
| 53 | 73 |
| 74 const char kAutoLoginUsername[] = "public_session_user@localhost"; |
| 75 const int kAutoLoginNoDelay = 0; |
| 76 const int kAutoLoginShortDelay = 100; |
| 77 const int kAutoLoginLongDelay = 10000; |
| 78 |
| 54 class MockLoginDisplay : public LoginDisplay { | 79 class MockLoginDisplay : public LoginDisplay { |
| 55 public: | 80 public: |
| 56 MockLoginDisplay() | 81 MockLoginDisplay() |
| 57 : LoginDisplay(NULL, gfx::Rect()) { | 82 : LoginDisplay(NULL, gfx::Rect()) { |
| 58 } | 83 } |
| 59 | 84 |
| 60 MOCK_METHOD4(Init, void(const UserList&, bool, bool, bool)); | 85 MOCK_METHOD4(Init, void(const UserList&, bool, bool, bool)); |
| 61 MOCK_METHOD0(OnPreferencesChanged, void(void)); | 86 MOCK_METHOD0(OnPreferencesChanged, void(void)); |
| 62 MOCK_METHOD1(OnUserImageChanged, void(const User&)); | 87 MOCK_METHOD1(OnUserImageChanged, void(const User&)); |
| 63 MOCK_METHOD0(OnFadeOut, void(void)); | 88 MOCK_METHOD0(OnFadeOut, void(void)); |
| (...skipping 30 matching lines...) Expand all Loading... |
| 94 MOCK_METHOD0(CheckForAutoEnrollment, void(void)); | 119 MOCK_METHOD0(CheckForAutoEnrollment, void(void)); |
| 95 MOCK_METHOD2(StartWizard, void(const std::string&, DictionaryValue*)); | 120 MOCK_METHOD2(StartWizard, void(const std::string&, DictionaryValue*)); |
| 96 MOCK_METHOD0(StartSignInScreen, void(void)); | 121 MOCK_METHOD0(StartSignInScreen, void(void)); |
| 97 MOCK_METHOD0(ResumeSignInScreen, void(void)); | 122 MOCK_METHOD0(ResumeSignInScreen, void(void)); |
| 98 MOCK_METHOD0(OnPreferencesChanged, void(void)); | 123 MOCK_METHOD0(OnPreferencesChanged, void(void)); |
| 99 | 124 |
| 100 private: | 125 private: |
| 101 DISALLOW_COPY_AND_ASSIGN(MockLoginDisplayHost); | 126 DISALLOW_COPY_AND_ASSIGN(MockLoginDisplayHost); |
| 102 }; | 127 }; |
| 103 | 128 |
| 129 class MockCloudPolicyStoreObserver : public policy::CloudPolicyStore::Observer { |
| 130 public: |
| 131 MockCloudPolicyStoreObserver() { |
| 132 } |
| 133 |
| 134 MOCK_METHOD1(OnStoreLoaded, void(policy::CloudPolicyStore*)); |
| 135 MOCK_METHOD1(OnStoreError, void(policy::CloudPolicyStore*)); |
| 136 |
| 137 private: |
| 138 DISALLOW_COPY_AND_ASSIGN(MockCloudPolicyStoreObserver); |
| 139 }; |
| 140 |
| 104 scoped_refptr<Authenticator> CreateAuthenticator( | 141 scoped_refptr<Authenticator> CreateAuthenticator( |
| 105 LoginStatusConsumer* consumer) { | 142 LoginStatusConsumer* consumer) { |
| 106 return new MockAuthenticator(consumer, kUsername, kPassword); | 143 return new MockAuthenticator(consumer, kUsername, kPassword); |
| 107 } | 144 } |
| 108 | 145 |
| 109 scoped_refptr<Authenticator> CreateAuthenticatorNewUser( | 146 scoped_refptr<Authenticator> CreateAuthenticatorNewUser( |
| 110 LoginStatusConsumer* consumer) { | 147 LoginStatusConsumer* consumer) { |
| 111 return new MockAuthenticator(consumer, kNewUsername, kPassword); | 148 return new MockAuthenticator(consumer, kNewUsername, kPassword); |
| 112 } | 149 } |
| 113 | 150 |
| 151 scoped_refptr<Authenticator> CreateAuthenticatorPublicSession( |
| 152 LoginStatusConsumer* consumer) { |
| 153 return new MockAuthenticator(consumer, kAutoLoginUsername, ""); |
| 154 } |
| 155 |
| 114 } // namespace | 156 } // namespace |
| 115 | 157 |
| 116 class ExistingUserControllerTest : public CrosInProcessBrowserTest { | 158 class ExistingUserControllerTest : public CrosInProcessBrowserTest { |
| 117 protected: | 159 protected: |
| 118 ExistingUserControllerTest() | 160 ExistingUserControllerTest() |
| 119 : mock_network_library_(NULL), | 161 : mock_network_library_(NULL), |
| 120 mock_login_display_(NULL), | 162 mock_login_display_(NULL), |
| 121 mock_login_display_host_(NULL), | 163 mock_login_display_host_(NULL), |
| 122 testing_profile_(NULL) { | 164 testing_profile_(NULL) { |
| 123 } | 165 } |
| (...skipping 12 matching lines...) Expand all Loading... |
| 136 Return(reinterpret_cast<IBusInputContextClient*>(NULL))); | 178 Return(reinterpret_cast<IBusInputContextClient*>(NULL))); |
| 137 EXPECT_CALL(*mock_dbus_thread_manager->mock_shill_manager_client(), | 179 EXPECT_CALL(*mock_dbus_thread_manager->mock_shill_manager_client(), |
| 138 GetProperties(_)) | 180 GetProperties(_)) |
| 139 .Times(AnyNumber()); | 181 .Times(AnyNumber()); |
| 140 EXPECT_CALL(*mock_dbus_thread_manager->mock_shill_manager_client(), | 182 EXPECT_CALL(*mock_dbus_thread_manager->mock_shill_manager_client(), |
| 141 AddPropertyChangedObserver(_)) | 183 AddPropertyChangedObserver(_)) |
| 142 .Times(AnyNumber()); | 184 .Times(AnyNumber()); |
| 143 EXPECT_CALL(*mock_dbus_thread_manager->mock_shill_manager_client(), | 185 EXPECT_CALL(*mock_dbus_thread_manager->mock_shill_manager_client(), |
| 144 RemovePropertyChangedObserver(_)) | 186 RemovePropertyChangedObserver(_)) |
| 145 .Times(AnyNumber()); | 187 .Times(AnyNumber()); |
| 188 |
| 189 SetUpSessionManager(mock_dbus_thread_manager); |
| 190 |
| 146 DBusThreadManager::InitializeForTesting(mock_dbus_thread_manager); | 191 DBusThreadManager::InitializeForTesting(mock_dbus_thread_manager); |
| 147 CrosInProcessBrowserTest::SetUpInProcessBrowserTestFixture(); | 192 CrosInProcessBrowserTest::SetUpInProcessBrowserTestFixture(); |
| 148 cros_mock_->InitStatusAreaMocks(); | 193 cros_mock_->InitStatusAreaMocks(); |
| 149 cros_mock_->SetStatusAreaMocksExpectations(); | 194 cros_mock_->SetStatusAreaMocksExpectations(); |
| 150 | 195 |
| 151 mock_network_library_ = cros_mock_->mock_network_library(); | 196 mock_network_library_ = cros_mock_->mock_network_library(); |
| 152 EXPECT_CALL(*mock_network_library_, AddUserActionObserver(_)) | 197 EXPECT_CALL(*mock_network_library_, AddUserActionObserver(_)) |
| 153 .Times(AnyNumber()); | 198 .Times(AnyNumber()); |
| 154 EXPECT_CALL(*mock_network_library_, LoadOncNetworks(_, _, _, _)) | 199 EXPECT_CALL(*mock_network_library_, LoadOncNetworks(_, _, _, _)) |
| 155 .WillRepeatedly(Return(true)); | 200 .WillRepeatedly(Return(true)); |
| 156 | 201 |
| 157 MockSessionManagerClient* mock_session_manager_client = | |
| 158 mock_dbus_thread_manager->mock_session_manager_client(); | |
| 159 EXPECT_CALL(*mock_session_manager_client, EmitLoginPromptReady()) | |
| 160 .Times(1); | |
| 161 EXPECT_CALL(*mock_session_manager_client, RetrieveDevicePolicy(_)) | |
| 162 .Times(AnyNumber()); | |
| 163 | |
| 164 mock_login_utils_ = new MockLoginUtils(); | 202 mock_login_utils_ = new MockLoginUtils(); |
| 165 LoginUtils::Set(mock_login_utils_); | 203 LoginUtils::Set(mock_login_utils_); |
| 166 EXPECT_CALL(*mock_login_utils_, PrewarmAuthentication()) | 204 EXPECT_CALL(*mock_login_utils_, PrewarmAuthentication()) |
| 167 .Times(AnyNumber()); | 205 .Times(AnyNumber()); |
| 168 EXPECT_CALL(*mock_login_utils_, StopBackgroundFetchers()) | 206 EXPECT_CALL(*mock_login_utils_, StopBackgroundFetchers()) |
| 169 .Times(AnyNumber()); | 207 .Times(AnyNumber()); |
| 170 EXPECT_CALL(*mock_login_utils_, DelegateDeleted(_)) | 208 EXPECT_CALL(*mock_login_utils_, DelegateDeleted(_)) |
| 171 .Times(1); | 209 .Times(1); |
| 172 | 210 |
| 173 mock_login_display_host_.reset(new MockLoginDisplayHost()); | 211 mock_login_display_host_.reset(new MockLoginDisplayHost()); |
| 212 mock_login_display_ = new MockLoginDisplay(); |
| 213 SetUpLoginDisplay(); |
| 214 } |
| 174 | 215 |
| 175 EXPECT_CALL(*mock_user_manager_.user_manager(), IsKnownUser(kUsername)) | 216 virtual void SetUpSessionManager( |
| 217 MockDBusThreadManager* mock_dbus_thread_manager) { |
| 218 mock_user_manager_.reset(new ScopedMockUserManagerEnabler); |
| 219 EXPECT_CALL(*mock_user_manager_->user_manager(), IsKnownUser(kUsername)) |
| 176 .Times(AnyNumber()) | 220 .Times(AnyNumber()) |
| 177 .WillRepeatedly(Return(true)); | 221 .WillRepeatedly(Return(true)); |
| 178 EXPECT_CALL(*mock_user_manager_.user_manager(), IsKnownUser(kNewUsername)) | 222 EXPECT_CALL(*mock_user_manager_->user_manager(), IsKnownUser(kNewUsername)) |
| 179 .Times(AnyNumber()) | 223 .Times(AnyNumber()) |
| 180 .WillRepeatedly(Return(false)); | 224 .WillRepeatedly(Return(false)); |
| 181 EXPECT_CALL(*mock_user_manager_.user_manager(), IsUserLoggedIn()) | 225 EXPECT_CALL(*mock_user_manager_->user_manager(), IsUserLoggedIn()) |
| 182 .Times(AnyNumber()) | 226 .Times(AnyNumber()) |
| 183 .WillRepeatedly(Return(false)); | 227 .WillRepeatedly(Return(false)); |
| 184 EXPECT_CALL(*mock_user_manager_.user_manager(), IsLoggedInAsGuest()) | 228 EXPECT_CALL(*mock_user_manager_->user_manager(), IsLoggedInAsGuest()) |
| 185 .Times(AnyNumber()) | 229 .Times(AnyNumber()) |
| 186 .WillRepeatedly(Return(false)); | 230 .WillRepeatedly(Return(false)); |
| 187 EXPECT_CALL(*mock_user_manager_.user_manager(), IsLoggedInAsDemoUser()) | 231 EXPECT_CALL(*mock_user_manager_->user_manager(), IsLoggedInAsDemoUser()) |
| 188 .Times(AnyNumber()) | 232 .Times(AnyNumber()) |
| 189 .WillRepeatedly(Return(false)); | 233 .WillRepeatedly(Return(false)); |
| 190 EXPECT_CALL(*mock_user_manager_.user_manager(), IsLoggedInAsPublicAccount()) | 234 EXPECT_CALL(*mock_user_manager_->user_manager(), |
| 235 IsLoggedInAsPublicAccount()) |
| 191 .Times(AnyNumber()) | 236 .Times(AnyNumber()) |
| 192 .WillRepeatedly(Return(false)); | 237 .WillRepeatedly(Return(false)); |
| 193 EXPECT_CALL(*mock_user_manager_.user_manager(), IsSessionStarted()) | 238 EXPECT_CALL(*mock_user_manager_->user_manager(), IsSessionStarted()) |
| 194 .Times(AnyNumber()) | 239 .Times(AnyNumber()) |
| 195 .WillRepeatedly(Return(false)); | 240 .WillRepeatedly(Return(false)); |
| 241 EXPECT_CALL(*mock_user_manager_->user_manager(), IsCurrentUserNew()) |
| 242 .Times(AnyNumber()) |
| 243 .WillRepeatedly(Return(false)); |
| 244 EXPECT_CALL(*mock_user_manager_->user_manager(), Shutdown()) |
| 245 .Times(1); |
| 196 | 246 |
| 247 MockSessionManagerClient* mock_session_manager_client = |
| 248 mock_dbus_thread_manager->mock_session_manager_client(); |
| 249 EXPECT_CALL(*mock_session_manager_client, EmitLoginPromptReady()) |
| 250 .Times(1); |
| 251 EXPECT_CALL(*mock_session_manager_client, RetrieveDevicePolicy(_)) |
| 252 .Times(AnyNumber()); |
| 253 } |
| 254 |
| 255 virtual void SetUpLoginDisplay() { |
| 197 // |mock_login_display_| is owned by the ExistingUserController, which calls | 256 // |mock_login_display_| is owned by the ExistingUserController, which calls |
| 198 // CreateLoginDisplay() on the |mock_login_display_host_| to get it. | 257 // CreateLoginDisplay() on the |mock_login_display_host_| to get it. |
| 199 mock_login_display_ = new MockLoginDisplay(); | |
| 200 EXPECT_CALL(*mock_login_display_host_.get(), CreateLoginDisplay(_)) | 258 EXPECT_CALL(*mock_login_display_host_.get(), CreateLoginDisplay(_)) |
| 201 .Times(1) | 259 .Times(1) |
| 202 .WillOnce(Return(mock_login_display_)); | 260 .WillOnce(Return(mock_login_display_)); |
| 203 EXPECT_CALL(*mock_login_display_host_.get(), GetNativeWindow()) | 261 EXPECT_CALL(*mock_login_display_host_.get(), GetNativeWindow()) |
| 204 .Times(1) | 262 .Times(1) |
| 205 .WillOnce(ReturnNull()); | 263 .WillOnce(ReturnNull()); |
| 206 EXPECT_CALL(*mock_login_display_host_.get(), OnPreferencesChanged()) | 264 EXPECT_CALL(*mock_login_display_host_.get(), OnPreferencesChanged()) |
| 207 .Times(1); | 265 .Times(1); |
| 208 EXPECT_CALL(*mock_login_display_, Init(_, false, true, true)) | 266 EXPECT_CALL(*mock_login_display_, Init(_, false, true, true)) |
| 209 .Times(1); | 267 .Times(1); |
| 210 } | 268 } |
| 211 | 269 |
| 212 virtual void SetUpCommandLine(CommandLine* command_line) OVERRIDE { | 270 virtual void SetUpCommandLine(CommandLine* command_line) OVERRIDE { |
| 213 command_line->AppendSwitch(switches::kLoginManager); | 271 command_line->AppendSwitch(switches::kLoginManager); |
| 214 } | 272 } |
| 215 | 273 |
| 216 virtual void SetUpOnMainThread() OVERRIDE { | 274 virtual void SetUpOnMainThread() OVERRIDE { |
| 217 testing_profile_.reset(new TestingProfile()); | 275 testing_profile_.reset(new TestingProfile()); |
| 218 existing_user_controller_.reset( | 276 existing_user_controller_.reset( |
| 219 new ExistingUserController(mock_login_display_host_.get())); | 277 new ExistingUserController(mock_login_display_host_.get())); |
| 220 ASSERT_EQ(existing_user_controller(), existing_user_controller_.get()); | 278 ASSERT_EQ(existing_user_controller(), existing_user_controller_.get()); |
| 221 existing_user_controller_->Init(UserList()); | 279 existing_user_controller_->Init(UserList()); |
| 222 profile_prepared_cb_ = | 280 profile_prepared_cb_ = |
| 223 base::Bind(&ExistingUserController::OnProfilePrepared, | 281 base::Bind(&ExistingUserController::OnProfilePrepared, |
| 224 base::Unretained(existing_user_controller()), | 282 base::Unretained(existing_user_controller()), |
| 225 testing_profile_.get()); | 283 testing_profile_.get()); |
| 226 } | 284 } |
| 227 | 285 |
| 228 virtual void CleanUpOnMainThread() OVERRIDE { | 286 virtual void CleanUpOnMainThread() OVERRIDE { |
| 287 // ExistingUserController must be deleted before the thread is cleaned up: |
| 288 // if there is an outstanding login attempt when ExistingUserController is |
| 289 // deleted, its LoginPerformer instance will be deleted, which in turn |
| 290 // deletes its OnlineAttemptHost instance. However, OnlineAttemptHost must |
| 291 // be deleted on the UI thread. |
| 292 existing_user_controller_.reset(); |
| 229 CrosInProcessBrowserTest::CleanUpOnMainThread(); | 293 CrosInProcessBrowserTest::CleanUpOnMainThread(); |
| 230 testing_profile_.reset(NULL); | 294 testing_profile_.reset(NULL); |
| 231 } | 295 } |
| 232 | 296 |
| 233 virtual void TearDownInProcessBrowserTestFixture() OVERRIDE { | 297 virtual void TearDownInProcessBrowserTestFixture() OVERRIDE { |
| 234 CrosInProcessBrowserTest::TearDownInProcessBrowserTestFixture(); | 298 CrosInProcessBrowserTest::TearDownInProcessBrowserTestFixture(); |
| 235 DBusThreadManager::Shutdown(); | 299 DBusThreadManager::Shutdown(); |
| 236 } | 300 } |
| 237 | 301 |
| 302 // ExistingUserController private member accessors. |
| 303 base::OneShotTimer<ExistingUserController>* auto_login_timer() { |
| 304 return &existing_user_controller()->auto_login_timer(); |
| 305 } |
| 306 |
| 307 std::string auto_login_username() { |
| 308 return existing_user_controller()->public_session_auto_login_username_; |
| 309 } |
| 310 void set_auto_login_username(const std::string& username) { |
| 311 existing_user_controller()->public_session_auto_login_username_ = username; |
| 312 } |
| 313 |
| 314 int auto_login_delay() { |
| 315 return existing_user_controller()->public_session_auto_login_delay_; |
| 316 } |
| 317 void set_auto_login_delay(int delay) { |
| 318 existing_user_controller()->public_session_auto_login_delay_ = delay; |
| 319 } |
| 320 |
| 321 bool is_login_in_progress() { |
| 322 return existing_user_controller()->is_login_in_progress_; |
| 323 } |
| 324 void set_is_login_in_progress(bool is_login_in_progress) { |
| 325 existing_user_controller()->is_login_in_progress_ = is_login_in_progress; |
| 326 } |
| 327 |
| 238 scoped_ptr<ExistingUserController> existing_user_controller_; | 328 scoped_ptr<ExistingUserController> existing_user_controller_; |
| 239 | 329 |
| 240 // These mocks are owned by CrosLibrary class. | 330 // These mocks are owned by CrosLibrary class. |
| 241 MockNetworkLibrary* mock_network_library_; | 331 MockNetworkLibrary* mock_network_library_; |
| 242 | 332 |
| 243 MockLoginDisplay* mock_login_display_; | 333 MockLoginDisplay* mock_login_display_; |
| 244 scoped_ptr<MockLoginDisplayHost> mock_login_display_host_; | 334 scoped_ptr<MockLoginDisplayHost> mock_login_display_host_; |
| 245 | 335 |
| 246 ScopedMockUserManagerEnabler mock_user_manager_; | 336 scoped_ptr<ScopedMockUserManagerEnabler> mock_user_manager_; |
| 247 | 337 |
| 248 // Owned by LoginUtilsWrapper. | 338 // Owned by LoginUtilsWrapper. |
| 249 MockLoginUtils* mock_login_utils_; | 339 MockLoginUtils* mock_login_utils_; |
| 250 | 340 |
| 251 scoped_ptr<TestingProfile> testing_profile_; | 341 scoped_ptr<TestingProfile> testing_profile_; |
| 252 | 342 |
| 253 // Mock URLFetcher. | 343 // Mock URLFetcher. |
| 254 MockURLFetcherFactory<SuccessFetcher> factory_; | 344 MockURLFetcherFactory<SuccessFetcher> factory_; |
| 255 | 345 |
| 256 base::Callback<void(void)> profile_prepared_cb_; | 346 base::Callback<void(void)> profile_prepared_cb_; |
| (...skipping 21 matching lines...) Expand all Loading... |
| 278 .Times(1); | 368 .Times(1); |
| 279 EXPECT_CALL(*mock_login_display_, OnLoginSuccess(kUsername)) | 369 EXPECT_CALL(*mock_login_display_, OnLoginSuccess(kUsername)) |
| 280 .Times(1); | 370 .Times(1); |
| 281 EXPECT_CALL(*mock_login_display_, SetUIEnabled(true)) | 371 EXPECT_CALL(*mock_login_display_, SetUIEnabled(true)) |
| 282 .Times(1); | 372 .Times(1); |
| 283 EXPECT_CALL(*mock_login_display_, OnFadeOut()) | 373 EXPECT_CALL(*mock_login_display_, OnFadeOut()) |
| 284 .Times(1); | 374 .Times(1); |
| 285 EXPECT_CALL(*mock_login_display_host_, | 375 EXPECT_CALL(*mock_login_display_host_, |
| 286 StartWizard(WizardController::kTermsOfServiceScreenName, NULL)) | 376 StartWizard(WizardController::kTermsOfServiceScreenName, NULL)) |
| 287 .Times(0); | 377 .Times(0); |
| 288 EXPECT_CALL(*mock_user_manager_.user_manager(), IsCurrentUserNew()) | 378 EXPECT_CALL(*mock_user_manager_->user_manager(), IsCurrentUserNew()) |
| 289 .Times(AnyNumber()) | 379 .Times(AnyNumber()) |
| 290 .WillRepeatedly(Return(false)); | 380 .WillRepeatedly(Return(false)); |
| 291 existing_user_controller()->Login(kUsername, kPassword); | 381 existing_user_controller()->Login(kUsername, kPassword); |
| 292 content::RunAllPendingInMessageLoop(); | 382 content::RunAllPendingInMessageLoop(); |
| 293 } | 383 } |
| 294 | 384 |
| 295 IN_PROC_BROWSER_TEST_F(ExistingUserControllerTest, AutoEnrollAfterSignIn) { | 385 IN_PROC_BROWSER_TEST_F(ExistingUserControllerTest, AutoEnrollAfterSignIn) { |
| 296 EXPECT_CALL(*mock_login_display_host_, | 386 EXPECT_CALL(*mock_login_display_host_, |
| 297 StartWizard(WizardController::kEnterpriseEnrollmentScreenName, _)) | 387 StartWizard(WizardController::kEnterpriseEnrollmentScreenName, _)) |
| 298 .Times(1); | 388 .Times(1); |
| 299 EXPECT_CALL(*mock_login_display_, OnFadeOut()) | 389 EXPECT_CALL(*mock_login_display_, OnFadeOut()) |
| 300 .Times(1); | 390 .Times(1); |
| 301 EXPECT_CALL(*mock_login_display_host_.get(), OnCompleteLogin()) | 391 EXPECT_CALL(*mock_login_display_host_.get(), OnCompleteLogin()) |
| 302 .Times(1); | 392 .Times(1); |
| 303 EXPECT_CALL(*mock_user_manager_.user_manager(), IsCurrentUserNew()) | 393 EXPECT_CALL(*mock_user_manager_->user_manager(), IsCurrentUserNew()) |
| 304 .Times(AnyNumber()) | 394 .Times(AnyNumber()) |
| 305 .WillRepeatedly(Return(false)); | 395 .WillRepeatedly(Return(false)); |
| 306 // The order of these expected calls matters: the UI if first disabled | 396 // The order of these expected calls matters: the UI if first disabled |
| 307 // during the login sequence, and is enabled again for the enrollment screen. | 397 // during the login sequence, and is enabled again for the enrollment screen. |
| 308 Sequence uiEnabledSequence; | 398 Sequence uiEnabledSequence; |
| 309 EXPECT_CALL(*mock_login_display_, SetUIEnabled(false)) | 399 EXPECT_CALL(*mock_login_display_, SetUIEnabled(false)) |
| 310 .Times(1) | 400 .Times(1) |
| 311 .InSequence(uiEnabledSequence); | 401 .InSequence(uiEnabledSequence); |
| 312 EXPECT_CALL(*mock_login_display_, SetUIEnabled(true)) | 402 EXPECT_CALL(*mock_login_display_, SetUIEnabled(true)) |
| 313 .Times(1) | 403 .Times(1) |
| (...skipping 24 matching lines...) Expand all Loading... |
| 338 PrepareProfile(kNewUsername, _, kPassword, _, _, _)) | 428 PrepareProfile(kNewUsername, _, kPassword, _, _, _)) |
| 339 .Times(1) | 429 .Times(1) |
| 340 .WillOnce(InvokeWithoutArgs(&profile_prepared_cb_, | 430 .WillOnce(InvokeWithoutArgs(&profile_prepared_cb_, |
| 341 &base::Callback<void(void)>::Run)); | 431 &base::Callback<void(void)>::Run)); |
| 342 EXPECT_CALL(*mock_login_display_, OnLoginSuccess(kNewUsername)) | 432 EXPECT_CALL(*mock_login_display_, OnLoginSuccess(kNewUsername)) |
| 343 .Times(1); | 433 .Times(1); |
| 344 EXPECT_CALL(*mock_login_display_, OnFadeOut()) | 434 EXPECT_CALL(*mock_login_display_, OnFadeOut()) |
| 345 .Times(1); | 435 .Times(1); |
| 346 EXPECT_CALL(*mock_login_display_host_.get(), OnCompleteLogin()) | 436 EXPECT_CALL(*mock_login_display_host_.get(), OnCompleteLogin()) |
| 347 .Times(1); | 437 .Times(1); |
| 348 EXPECT_CALL(*mock_user_manager_.user_manager(), IsCurrentUserNew()) | 438 EXPECT_CALL(*mock_user_manager_->user_manager(), IsCurrentUserNew()) |
| 349 .Times(AnyNumber()) | 439 .Times(AnyNumber()) |
| 350 .WillRepeatedly(Return(true)); | 440 .WillRepeatedly(Return(true)); |
| 351 | 441 |
| 352 // The order of these expected calls matters: the UI if first disabled | 442 // The order of these expected calls matters: the UI if first disabled |
| 353 // during the login sequence, and is enabled again after login completion. | 443 // during the login sequence, and is enabled again after login completion. |
| 354 Sequence uiEnabledSequence; | 444 Sequence uiEnabledSequence; |
| 355 // This is disabled twice: once right after signin but before checking for | 445 // This is disabled twice: once right after signin but before checking for |
| 356 // auto-enrollment, and again after doing an ownership status check. | 446 // auto-enrollment, and again after doing an ownership status check. |
| 357 EXPECT_CALL(*mock_login_display_, SetUIEnabled(false)) | 447 EXPECT_CALL(*mock_login_display_, SetUIEnabled(false)) |
| 358 .Times(2) | 448 .Times(2) |
| 359 .InSequence(uiEnabledSequence); | 449 .InSequence(uiEnabledSequence); |
| 360 EXPECT_CALL(*mock_login_display_, SetUIEnabled(true)) | 450 EXPECT_CALL(*mock_login_display_, SetUIEnabled(true)) |
| 361 .Times(1) | 451 .Times(1) |
| 362 .InSequence(uiEnabledSequence); | 452 .InSequence(uiEnabledSequence); |
| 363 | 453 |
| 364 existing_user_controller()->CompleteLogin(kNewUsername, kPassword); | 454 existing_user_controller()->CompleteLogin(kNewUsername, kPassword); |
| 365 content::RunAllPendingInMessageLoop(); | 455 content::RunAllPendingInMessageLoop(); |
| 366 } | 456 } |
| 367 | 457 |
| 458 MATCHER_P(HasDetails, expected, "") { |
| 459 return expected == *content::Details<const std::string>(arg).ptr(); |
| 460 } |
| 461 |
| 462 class ExistingUserControllerPublicSessionTest |
| 463 : public ExistingUserControllerTest { |
| 464 protected: |
| 465 ExistingUserControllerPublicSessionTest() { |
| 466 } |
| 467 |
| 468 virtual void SetUpOnMainThread() OVERRIDE { |
| 469 ExistingUserControllerTest::SetUpOnMainThread(); |
| 470 |
| 471 // Wait for the public session user to be created. |
| 472 if (!chromeos::UserManager::Get()->IsKnownUser(kAutoLoginUsername)) { |
| 473 content::NotificationWatcher( |
| 474 chrome::NOTIFICATION_USER_LIST_CHANGED, |
| 475 base::Bind(&chromeos::UserManager::IsKnownUser, |
| 476 base::Unretained(chromeos::UserManager::Get()), |
| 477 kAutoLoginUsername)).Run(); |
| 478 } |
| 479 |
| 480 // Wait for the device local account policy to be installed. |
| 481 MockCloudPolicyStoreObserver observer; |
| 482 content::MessageLoopRunner* runner = new content::MessageLoopRunner; |
| 483 policy::CloudPolicyStore* store = TestingBrowserProcess::GetGlobal()-> |
| 484 browser_policy_connector()->GetDeviceLocalAccountPolicyService()-> |
| 485 GetBrokerForAccount(kAutoLoginUsername)->core()->store(); |
| 486 store->AddObserver(&observer); |
| 487 EXPECT_CALL(observer, OnStoreLoaded(store)) |
| 488 .Times(1) |
| 489 .WillOnce(InvokeWithoutArgs(runner, &content::MessageLoopRunner::Quit)); |
| 490 runner->Run(); |
| 491 store->RemoveObserver(&observer); |
| 492 } |
| 493 |
| 494 virtual void SetUpSessionManager( |
| 495 MockDBusThreadManager* mock_dbus_thread_manager) OVERRIDE { |
| 496 EXPECT_CALL(*mock_dbus_thread_manager, GetSessionManagerClient()) |
| 497 .WillRepeatedly(Return(&session_manager_client_)); |
| 498 |
| 499 // Install the owner key. |
| 500 ASSERT_TRUE(temp_dir_.CreateUniqueTempDir()); |
| 501 base::FilePath owner_key_file = temp_dir_.path().AppendASCII("owner.key"); |
| 502 std::vector<uint8> owner_key_bits; |
| 503 ASSERT_TRUE(device_policy_.signing_key()->ExportPublicKey(&owner_key_bits)); |
| 504 ASSERT_EQ( |
| 505 file_util::WriteFile( |
| 506 owner_key_file, |
| 507 reinterpret_cast<const char*>(vector_as_array(&owner_key_bits)), |
| 508 owner_key_bits.size()), |
| 509 static_cast<int>(owner_key_bits.size())); |
| 510 ASSERT_TRUE(PathService::Override(chrome::FILE_OWNER_KEY, owner_key_file)); |
| 511 |
| 512 // Setup the device policy. |
| 513 em::ChromeDeviceSettingsProto& proto(device_policy_.payload()); |
| 514 proto.mutable_device_local_accounts()->add_account()->set_id( |
| 515 kAutoLoginUsername); |
| 516 RefreshDevicePolicy(); |
| 517 |
| 518 // Setup the device local account policy. |
| 519 policy::UserPolicyBuilder device_local_account_policy; |
| 520 device_local_account_policy.policy_data().set_username(kAutoLoginUsername); |
| 521 device_local_account_policy.policy_data().set_policy_type( |
| 522 policy::dm_protocol::kChromePublicAccountPolicyType); |
| 523 device_local_account_policy.policy_data().set_settings_entity_id( |
| 524 kAutoLoginUsername); |
| 525 device_local_account_policy.Build(); |
| 526 session_manager_client_.set_device_local_account_policy( |
| 527 kAutoLoginUsername, |
| 528 device_local_account_policy.GetBlob()); |
| 529 } |
| 530 |
| 531 virtual void SetUpLoginDisplay() { |
| 532 EXPECT_CALL(*mock_login_display_host_.get(), CreateLoginDisplay(_)) |
| 533 .Times(1) |
| 534 .WillOnce(Return(mock_login_display_)); |
| 535 EXPECT_CALL(*mock_login_display_host_.get(), GetNativeWindow()) |
| 536 .Times(AnyNumber()) |
| 537 .WillRepeatedly(ReturnNull()); |
| 538 EXPECT_CALL(*mock_login_display_host_.get(), OnPreferencesChanged()) |
| 539 .Times(AnyNumber()); |
| 540 EXPECT_CALL(*mock_login_display_, Init(_, _, _, _)) |
| 541 .Times(AnyNumber()); |
| 542 } |
| 543 |
| 544 void DisableAutoLoginPolicyNotifications() { |
| 545 CrosSettings::Get()->RemoveSettingsObserver( |
| 546 kAccountsPrefDeviceLocalAccountAutoLoginId, |
| 547 existing_user_controller()); |
| 548 CrosSettings::Get()->RemoveSettingsObserver( |
| 549 kAccountsPrefDeviceLocalAccountAutoLoginDelay, |
| 550 existing_user_controller()); |
| 551 } |
| 552 |
| 553 void ExpectSuccessfulLogin(const std::string& username, |
| 554 const std::string& password, |
| 555 scoped_refptr<Authenticator> create_authenticator( |
| 556 LoginStatusConsumer* consumer)) { |
| 557 EXPECT_CALL(*mock_login_display_, SetUIEnabled(false)) |
| 558 .Times(AnyNumber()); |
| 559 EXPECT_CALL(*mock_login_utils_, CreateAuthenticator(_)) |
| 560 .Times(1) |
| 561 .WillOnce(WithArg<0>(Invoke(create_authenticator))); |
| 562 EXPECT_CALL(*mock_login_utils_, |
| 563 PrepareProfile(username, _, password, _, _, _)) |
| 564 .Times(1) |
| 565 .WillOnce(InvokeWithoutArgs(&profile_prepared_cb_, |
| 566 &base::Callback<void(void)>::Run)); |
| 567 EXPECT_CALL(*mock_login_utils_, |
| 568 DoBrowserLaunch(testing_profile_.get(), |
| 569 mock_login_display_host_.get())) |
| 570 .Times(1); |
| 571 EXPECT_CALL(*mock_login_display_, OnLoginSuccess(username)) |
| 572 .Times(1); |
| 573 EXPECT_CALL(*mock_login_display_, SetUIEnabled(true)) |
| 574 .Times(1); |
| 575 EXPECT_CALL(*mock_login_display_, OnFadeOut()) |
| 576 .Times(1); |
| 577 EXPECT_CALL(*mock_login_display_host_, |
| 578 StartWizard(WizardController::kTermsOfServiceScreenName, NULL)) |
| 579 .Times(0); |
| 580 } |
| 581 |
| 582 content::MessageLoopRunner* CreateSettingsObserverRunLoop( |
| 583 content::MockNotificationObserver& observer, const char* setting) { |
| 584 content::MessageLoopRunner* runner = new content::MessageLoopRunner; |
| 585 EXPECT_CALL(observer, Observe(chrome::NOTIFICATION_SYSTEM_SETTING_CHANGED, |
| 586 _, HasDetails(setting))) |
| 587 .Times(1) |
| 588 .WillOnce(InvokeWithoutArgs(runner, &content::MessageLoopRunner::Quit)); |
| 589 CrosSettings::Get()->AddSettingsObserver(setting, &observer); |
| 590 return runner; |
| 591 } |
| 592 |
| 593 void RefreshDevicePolicy() { |
| 594 // Reset the key to its original state. |
| 595 device_policy_.set_signing_key( |
| 596 policy::PolicyBuilder::CreateTestSigningKey()); |
| 597 device_policy_.Build(); |
| 598 // Clear the key so the device can't write owner settings. |
| 599 device_policy_.set_signing_key( |
| 600 make_scoped_ptr<crypto::RSAPrivateKey>(NULL)); |
| 601 device_policy_.set_new_signing_key( |
| 602 make_scoped_ptr<crypto::RSAPrivateKey>(NULL)); |
| 603 session_manager_client_.set_device_policy(device_policy_.GetBlob()); |
| 604 } |
| 605 |
| 606 void SetAutoLoginPolicy(const std::string& username, int delay) { |
| 607 // Wait until ExistingUserController has finished auto-login |
| 608 // configuration by observing the same settings that trigger |
| 609 // ConfigurePublicSessionAutoLogin. |
| 610 content::MockNotificationObserver observer; |
| 611 |
| 612 em::ChromeDeviceSettingsProto& proto(device_policy_.payload()); |
| 613 |
| 614 // If both settings have changed we need to wait for both to |
| 615 // propagate, so check the new values against the old ones. |
| 616 content::MessageLoopRunner* runner1 = NULL; |
| 617 if (!proto.has_device_local_accounts() || |
| 618 !proto.device_local_accounts().has_auto_login_id() || |
| 619 proto.device_local_accounts().auto_login_id() != username) { |
| 620 runner1 = CreateSettingsObserverRunLoop( |
| 621 observer, kAccountsPrefDeviceLocalAccountAutoLoginId); |
| 622 } |
| 623 content::MessageLoopRunner* runner2 = NULL; |
| 624 if (!proto.has_device_local_accounts() || |
| 625 !proto.device_local_accounts().has_auto_login_delay() || |
| 626 proto.device_local_accounts().auto_login_delay() != delay) { |
| 627 runner2 = CreateSettingsObserverRunLoop( |
| 628 observer, kAccountsPrefDeviceLocalAccountAutoLoginDelay); |
| 629 } |
| 630 |
| 631 // Update the policy. |
| 632 proto.mutable_device_local_accounts()->set_auto_login_id(username); |
| 633 proto.mutable_device_local_accounts()->set_auto_login_delay(delay); |
| 634 RefreshDevicePolicy(); |
| 635 |
| 636 // Wait for ExistingUserController. |
| 637 if (runner1) |
| 638 runner1->Run(); |
| 639 if (runner2) |
| 640 runner2->Run(); |
| 641 |
| 642 // Clean up. |
| 643 CrosSettings::Get()->RemoveSettingsObserver( |
| 644 kAccountsPrefDeviceLocalAccountAutoLoginId, |
| 645 &observer); |
| 646 CrosSettings::Get()->RemoveSettingsObserver( |
| 647 kAccountsPrefDeviceLocalAccountAutoLoginDelay, |
| 648 &observer); |
| 649 } |
| 650 |
| 651 // Enables public sessions in tests. |
| 652 FakeSessionManagerClient session_manager_client_; |
| 653 |
| 654 // Stores the device owner key. |
| 655 base::ScopedTempDir temp_dir_; |
| 656 |
| 657 // Carries Chrome OS device policies for tests. |
| 658 policy::DevicePolicyBuilder device_policy_; |
| 659 |
| 660 private: |
| 661 DISALLOW_COPY_AND_ASSIGN(ExistingUserControllerPublicSessionTest); |
| 662 }; |
| 663 |
| 664 IN_PROC_BROWSER_TEST_F(ExistingUserControllerPublicSessionTest, |
| 665 StartAutoLoginTimer) { |
| 666 DisableAutoLoginPolicyNotifications(); |
| 667 |
| 668 // Timer shouldn't start until signin screen is ready. |
| 669 set_auto_login_username(kAutoLoginUsername); |
| 670 set_auto_login_delay(kAutoLoginLongDelay); |
| 671 existing_user_controller()->StartPublicSessionAutoLoginTimer(); |
| 672 EXPECT_FALSE(auto_login_timer()->IsRunning()); |
| 673 |
| 674 // Timer shouldn't start if the policy isn't set. |
| 675 set_auto_login_username(""); |
| 676 existing_user_controller()->OnSigninScreenReady(); |
| 677 existing_user_controller()->StartPublicSessionAutoLoginTimer(); |
| 678 EXPECT_FALSE(auto_login_timer()->IsRunning()); |
| 679 |
| 680 // Timer shouldn't fire in the middle of a login attempt. |
| 681 set_auto_login_username(kAutoLoginUsername); |
| 682 set_is_login_in_progress(true); |
| 683 existing_user_controller()->StartPublicSessionAutoLoginTimer(); |
| 684 EXPECT_FALSE(auto_login_timer()->IsRunning()); |
| 685 |
| 686 // Otherwise start. |
| 687 set_is_login_in_progress(false); |
| 688 existing_user_controller()->StartPublicSessionAutoLoginTimer(); |
| 689 EXPECT_TRUE(auto_login_timer()->IsRunning()); |
| 690 EXPECT_EQ(auto_login_timer()->GetCurrentDelay().InMilliseconds(), |
| 691 kAutoLoginLongDelay); |
| 692 } |
| 693 |
| 694 IN_PROC_BROWSER_TEST_F(ExistingUserControllerPublicSessionTest, |
| 695 StopAutoLoginTimer) { |
| 696 existing_user_controller()->OnSigninScreenReady(); |
| 697 set_auto_login_username(kAutoLoginUsername); |
| 698 set_auto_login_delay(kAutoLoginLongDelay); |
| 699 |
| 700 existing_user_controller()->StartPublicSessionAutoLoginTimer(); |
| 701 EXPECT_TRUE(auto_login_timer()->IsRunning()); |
| 702 |
| 703 existing_user_controller()->StopPublicSessionAutoLoginTimer(); |
| 704 EXPECT_FALSE(auto_login_timer()->IsRunning()); |
| 705 } |
| 706 |
| 707 IN_PROC_BROWSER_TEST_F(ExistingUserControllerPublicSessionTest, |
| 708 UserActivityRestartsAutoLogin) { |
| 709 existing_user_controller()->OnSigninScreenReady(); |
| 710 set_auto_login_username(kAutoLoginUsername); |
| 711 |
| 712 // Timer starts off not running. |
| 713 EXPECT_FALSE(auto_login_timer()->IsRunning()); |
| 714 |
| 715 // When the timer isn't running, nothing should happen. |
| 716 existing_user_controller()->OnUserActivity(); |
| 717 EXPECT_FALSE(auto_login_timer()->IsRunning()); |
| 718 |
| 719 // Start the timer. |
| 720 set_auto_login_delay(kAutoLoginLongDelay); |
| 721 existing_user_controller()->StartPublicSessionAutoLoginTimer(); |
| 722 EXPECT_TRUE(auto_login_timer()->IsRunning()); |
| 723 EXPECT_EQ(auto_login_timer()->GetCurrentDelay().InMilliseconds(), |
| 724 kAutoLoginLongDelay); |
| 725 |
| 726 // User activity should restart the timer, so check to see that the |
| 727 // timer delay was modified. |
| 728 set_auto_login_delay(kAutoLoginShortDelay); |
| 729 existing_user_controller()->OnUserActivity(); |
| 730 EXPECT_TRUE(auto_login_timer()->IsRunning()); |
| 731 EXPECT_EQ(auto_login_timer()->GetCurrentDelay().InMilliseconds(), |
| 732 kAutoLoginShortDelay); |
| 733 } |
| 734 |
| 735 IN_PROC_BROWSER_TEST_F(ExistingUserControllerPublicSessionTest, |
| 736 ConfigureAutoLogin) { |
| 737 ash::UserActivityDetector* detector = |
| 738 ash::Shell::GetInstance()->user_activity_detector(); |
| 739 existing_user_controller()->OnSigninScreenReady(); |
| 740 |
| 741 // Turn off settings notifications to ExistingUserController. |
| 742 DisableAutoLoginPolicyNotifications(); |
| 743 |
| 744 // Timer shouldn't start when the policy is disabled. |
| 745 SetAutoLoginPolicy("", 0); |
| 746 existing_user_controller()->ConfigurePublicSessionAutoLogin(); |
| 747 EXPECT_FALSE(auto_login_timer()->IsRunning()); |
| 748 EXPECT_EQ(auto_login_timer()->GetCurrentDelay().InMilliseconds(), 0); |
| 749 EXPECT_EQ(auto_login_delay(), 0); |
| 750 EXPECT_EQ(auto_login_username(), ""); |
| 751 EXPECT_FALSE(detector->HasObserver(existing_user_controller())); |
| 752 |
| 753 // Timer shouldn't start when the delay alone is set. |
| 754 SetAutoLoginPolicy("", kAutoLoginShortDelay); |
| 755 existing_user_controller()->ConfigurePublicSessionAutoLogin(); |
| 756 EXPECT_FALSE(auto_login_timer()->IsRunning()); |
| 757 EXPECT_EQ(auto_login_timer()->GetCurrentDelay().InMilliseconds(), 0); |
| 758 EXPECT_EQ(auto_login_delay(), kAutoLoginShortDelay); |
| 759 EXPECT_EQ(auto_login_username(), ""); |
| 760 EXPECT_FALSE(detector->HasObserver(existing_user_controller())); |
| 761 |
| 762 // Timer should start when the username is set. |
| 763 SetAutoLoginPolicy(kAutoLoginUsername, kAutoLoginShortDelay); |
| 764 existing_user_controller()->ConfigurePublicSessionAutoLogin(); |
| 765 EXPECT_TRUE(auto_login_timer()->IsRunning()); |
| 766 EXPECT_EQ(auto_login_timer()->GetCurrentDelay().InMilliseconds(), |
| 767 kAutoLoginShortDelay); |
| 768 EXPECT_EQ(auto_login_delay(), kAutoLoginShortDelay); |
| 769 EXPECT_EQ(auto_login_username(), kAutoLoginUsername); |
| 770 EXPECT_TRUE(detector->HasObserver(existing_user_controller())); |
| 771 |
| 772 // Timer should restart when the delay is changed. |
| 773 SetAutoLoginPolicy(kAutoLoginUsername, kAutoLoginLongDelay); |
| 774 existing_user_controller()->ConfigurePublicSessionAutoLogin(); |
| 775 EXPECT_TRUE(auto_login_timer()->IsRunning()); |
| 776 EXPECT_EQ(auto_login_timer()->GetCurrentDelay().InMilliseconds(), |
| 777 kAutoLoginLongDelay); |
| 778 EXPECT_EQ(auto_login_delay(), kAutoLoginLongDelay); |
| 779 EXPECT_EQ(auto_login_username(), kAutoLoginUsername); |
| 780 EXPECT_TRUE(detector->HasObserver(existing_user_controller())); |
| 781 |
| 782 // Timer should stop when the username is unset. |
| 783 SetAutoLoginPolicy("", kAutoLoginLongDelay); |
| 784 existing_user_controller()->ConfigurePublicSessionAutoLogin(); |
| 785 EXPECT_FALSE(auto_login_timer()->IsRunning()); |
| 786 EXPECT_EQ(auto_login_timer()->GetCurrentDelay().InMilliseconds(), |
| 787 kAutoLoginLongDelay); |
| 788 EXPECT_EQ(auto_login_username(), ""); |
| 789 EXPECT_EQ(auto_login_delay(), kAutoLoginLongDelay); |
| 790 EXPECT_FALSE(detector->HasObserver(existing_user_controller())); |
| 791 } |
| 792 |
| 793 IN_PROC_BROWSER_TEST_F(ExistingUserControllerPublicSessionTest, |
| 794 ConfigureAutoLoginUsingPolicy) { |
| 795 ash::UserActivityDetector* detector = |
| 796 ash::Shell::GetInstance()->user_activity_detector(); |
| 797 existing_user_controller()->OnSigninScreenReady(); |
| 798 EXPECT_EQ("", auto_login_username()); |
| 799 EXPECT_EQ(0, auto_login_delay()); |
| 800 EXPECT_FALSE(auto_login_timer()->IsRunning()); |
| 801 EXPECT_FALSE(detector->HasObserver(existing_user_controller())); |
| 802 |
| 803 // Set the policy. |
| 804 SetAutoLoginPolicy(kAutoLoginUsername, kAutoLoginLongDelay); |
| 805 EXPECT_EQ(kAutoLoginUsername, auto_login_username()); |
| 806 EXPECT_EQ(kAutoLoginLongDelay, auto_login_delay()); |
| 807 EXPECT_TRUE(auto_login_timer()->IsRunning()); |
| 808 EXPECT_TRUE(detector->HasObserver(existing_user_controller())); |
| 809 |
| 810 // Unset the policy. |
| 811 SetAutoLoginPolicy("", 0); |
| 812 EXPECT_EQ("", auto_login_username()); |
| 813 EXPECT_EQ(0, auto_login_delay()); |
| 814 EXPECT_FALSE(auto_login_timer()->IsRunning()); |
| 815 EXPECT_FALSE(detector->HasObserver(existing_user_controller())); |
| 816 } |
| 817 |
| 818 IN_PROC_BROWSER_TEST_F(ExistingUserControllerPublicSessionTest, |
| 819 OnAutoLoginFire) { |
| 820 // Set up mocks to check login success. |
| 821 ExpectSuccessfulLogin(kAutoLoginUsername, "", |
| 822 CreateAuthenticatorPublicSession); |
| 823 existing_user_controller()->OnSigninScreenReady(); |
| 824 |
| 825 // Directly set auto-login parameters to avoid starting the timer. |
| 826 set_auto_login_username(kAutoLoginUsername); |
| 827 set_auto_login_delay(kAutoLoginLongDelay); |
| 828 |
| 829 // Manually fire auto-login and wait for the login tasks to complete. |
| 830 existing_user_controller()->OnPublicSessionAutoLoginTimerFire(); |
| 831 content::RunAllPendingInMessageLoop(); |
| 832 } |
| 833 |
| 834 IN_PROC_BROWSER_TEST_F(ExistingUserControllerPublicSessionTest, |
| 835 AutoLoginNoDelay) { |
| 836 // Set up mocks to check login success. |
| 837 ExpectSuccessfulLogin(kAutoLoginUsername, "", |
| 838 CreateAuthenticatorPublicSession); |
| 839 existing_user_controller()->OnSigninScreenReady(); |
| 840 |
| 841 // Start auto-login and wait for login tasks to complete. |
| 842 SetAutoLoginPolicy(kAutoLoginUsername, kAutoLoginNoDelay); |
| 843 content::RunAllPendingInMessageLoop(); |
| 844 } |
| 845 |
| 846 IN_PROC_BROWSER_TEST_F(ExistingUserControllerPublicSessionTest, |
| 847 AutoLoginShortDelay) { |
| 848 // Set up mocks to check login success. |
| 849 ExpectSuccessfulLogin(kAutoLoginUsername, "", |
| 850 CreateAuthenticatorPublicSession); |
| 851 existing_user_controller()->OnSigninScreenReady(); |
| 852 SetAutoLoginPolicy(kAutoLoginUsername, kAutoLoginShortDelay); |
| 853 ASSERT_TRUE(auto_login_timer()->IsRunning()); |
| 854 |
| 855 // Wait for the timer to fire. |
| 856 content::MessageLoopRunner* runner = new content::MessageLoopRunner; |
| 857 base::OneShotTimer<content::MessageLoopRunner> timer; |
| 858 timer.Start(FROM_HERE, |
| 859 base::TimeDelta::FromMilliseconds(2 * kAutoLoginShortDelay), |
| 860 base::Bind(&content::MessageLoopRunner::Quit, |
| 861 base::Unretained(runner))); |
| 862 runner->Run(); |
| 863 |
| 864 // Wait for login tasks to complete. |
| 865 content::RunAllPendingInMessageLoop(); |
| 866 } |
| 867 |
| 868 IN_PROC_BROWSER_TEST_F(ExistingUserControllerPublicSessionTest, |
| 869 LoginStopsAutoLogin) { |
| 870 // Set up mocks to check login success. |
| 871 ExpectSuccessfulLogin(kUsername, kPassword, CreateAuthenticator); |
| 872 |
| 873 existing_user_controller()->OnSigninScreenReady(); |
| 874 set_auto_login_username(kAutoLoginUsername); |
| 875 set_auto_login_delay(kAutoLoginLongDelay); |
| 876 existing_user_controller()->StartPublicSessionAutoLoginTimer(); |
| 877 EXPECT_TRUE(auto_login_timer()->IsRunning()); |
| 878 |
| 879 // Login and check that it stopped the timer. |
| 880 existing_user_controller()->Login(kUsername, kPassword); |
| 881 EXPECT_TRUE(is_login_in_progress()); |
| 882 EXPECT_FALSE(auto_login_timer()->IsRunning()); |
| 883 |
| 884 // Wait for login tasks to complete. |
| 885 content::RunAllPendingInMessageLoop(); |
| 886 |
| 887 // Timer should still be stopped after login completes. |
| 888 EXPECT_FALSE(auto_login_timer()->IsRunning()); |
| 889 } |
| 890 |
| 891 IN_PROC_BROWSER_TEST_F(ExistingUserControllerPublicSessionTest, |
| 892 GuestModeLoginStopsAutoLogin) { |
| 893 EXPECT_CALL(*mock_login_display_, SetUIEnabled(false)) |
| 894 .Times(1); |
| 895 EXPECT_CALL(*mock_login_utils_, CreateAuthenticator(_)) |
| 896 .Times(1) |
| 897 .WillOnce(WithArg<0>(Invoke(CreateAuthenticator))); |
| 898 ScopedMockUserManagerEnabler mock_user_manager; |
| 899 EXPECT_CALL(*mock_login_utils_, CompleteOffTheRecordLogin(_)) |
| 900 .Times(1); |
| 901 |
| 902 existing_user_controller()->OnSigninScreenReady(); |
| 903 set_auto_login_username(kAutoLoginUsername); |
| 904 set_auto_login_delay(kAutoLoginLongDelay); |
| 905 existing_user_controller()->StartPublicSessionAutoLoginTimer(); |
| 906 EXPECT_TRUE(auto_login_timer()->IsRunning()); |
| 907 |
| 908 // Login and check that it stopped the timer. |
| 909 existing_user_controller()->LoginAsGuest(); |
| 910 EXPECT_TRUE(is_login_in_progress()); |
| 911 EXPECT_FALSE(auto_login_timer()->IsRunning()); |
| 912 |
| 913 // Wait for login tasks to complete. |
| 914 content::RunAllPendingInMessageLoop(); |
| 915 |
| 916 // Timer should still be stopped after login completes. |
| 917 EXPECT_FALSE(auto_login_timer()->IsRunning()); |
| 918 } |
| 919 |
| 920 IN_PROC_BROWSER_TEST_F(ExistingUserControllerPublicSessionTest, |
| 921 CompleteLoginStopsAutoLogin) { |
| 922 // Set up mocks to check login success. |
| 923 ExpectSuccessfulLogin(kUsername, kPassword, CreateAuthenticator); |
| 924 EXPECT_CALL(*mock_login_display_host_, OnCompleteLogin()) |
| 925 .Times(1); |
| 926 |
| 927 existing_user_controller()->OnSigninScreenReady(); |
| 928 set_auto_login_username(kAutoLoginUsername); |
| 929 set_auto_login_delay(kAutoLoginLongDelay); |
| 930 existing_user_controller()->StartPublicSessionAutoLoginTimer(); |
| 931 EXPECT_TRUE(auto_login_timer()->IsRunning()); |
| 932 |
| 933 // Check that login completes and stops the timer. |
| 934 existing_user_controller()->CompleteLogin(kUsername, kPassword); |
| 935 EXPECT_FALSE(auto_login_timer()->IsRunning()); |
| 936 |
| 937 // Wait for login tasks to complete. |
| 938 content::RunAllPendingInMessageLoop(); |
| 939 |
| 940 // Timer should still be stopped after login completes. |
| 941 EXPECT_FALSE(auto_login_timer()->IsRunning()); |
| 942 } |
| 943 |
| 944 IN_PROC_BROWSER_TEST_F(ExistingUserControllerPublicSessionTest, |
| 945 PublicSessionLoginStopsAutoLogin) { |
| 946 // Set up mocks to check login success. |
| 947 ExpectSuccessfulLogin(kAutoLoginUsername, "", |
| 948 CreateAuthenticatorPublicSession); |
| 949 existing_user_controller()->OnSigninScreenReady(); |
| 950 SetAutoLoginPolicy(kAutoLoginUsername, kAutoLoginShortDelay); |
| 951 EXPECT_TRUE(auto_login_timer()->IsRunning()); |
| 952 |
| 953 // Login and check that it stopped the timer. |
| 954 existing_user_controller()->LoginAsPublicAccount(kAutoLoginUsername); |
| 955 EXPECT_TRUE(is_login_in_progress()); |
| 956 EXPECT_FALSE(auto_login_timer()->IsRunning()); |
| 957 |
| 958 // Wait for login tasks to complete. |
| 959 content::RunAllPendingInMessageLoop(); |
| 960 |
| 961 // Timer should still be stopped after login completes. |
| 962 EXPECT_FALSE(auto_login_timer()->IsRunning()); |
| 963 } |
| 964 |
| 368 } // namespace chromeos | 965 } // namespace chromeos |
| OLD | NEW |