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 <vector> | 5 #include <vector> |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/bind_helpers.h" | 8 #include "base/bind_helpers.h" |
9 #include "base/callback.h" | 9 #include "base/callback.h" |
10 #include "base/command_line.h" | 10 #include "base/command_line.h" |
(...skipping 11 matching lines...) Expand all Loading... | |
22 #include "chrome/browser/chromeos/login/ui/mock_login_display_host.h" | 22 #include "chrome/browser/chromeos/login/ui/mock_login_display_host.h" |
23 #include "chrome/browser/chromeos/login/users/mock_user_manager.h" | 23 #include "chrome/browser/chromeos/login/users/mock_user_manager.h" |
24 #include "chrome/browser/chromeos/login/users/user_manager.h" | 24 #include "chrome/browser/chromeos/login/users/user_manager.h" |
25 #include "chrome/browser/chromeos/login/wizard_controller.h" | 25 #include "chrome/browser/chromeos/login/wizard_controller.h" |
26 #include "chrome/browser/chromeos/policy/browser_policy_connector_chromeos.h" | 26 #include "chrome/browser/chromeos/policy/browser_policy_connector_chromeos.h" |
27 #include "chrome/browser/chromeos/policy/device_local_account.h" | 27 #include "chrome/browser/chromeos/policy/device_local_account.h" |
28 #include "chrome/browser/chromeos/policy/device_local_account_policy_service.h" | 28 #include "chrome/browser/chromeos/policy/device_local_account_policy_service.h" |
29 #include "chrome/browser/chromeos/policy/device_policy_cros_browser_test.h" | 29 #include "chrome/browser/chromeos/policy/device_policy_cros_browser_test.h" |
30 #include "chrome/browser/chromeos/policy/proto/chrome_device_policy.pb.h" | 30 #include "chrome/browser/chromeos/policy/proto/chrome_device_policy.pb.h" |
31 #include "chrome/browser/chromeos/settings/cros_settings.h" | 31 #include "chrome/browser/chromeos/settings/cros_settings.h" |
32 #include "chrome/common/chrome_switches.h" | 32 #include "chrome/common/chrome_switches.h" |
Nikita (slow)
2014/05/19 14:27:15
nit: not used
| |
33 #include "chrome/test/base/testing_browser_process.h" | 33 #include "chrome/test/base/testing_browser_process.h" |
34 #include "chrome/test/base/testing_profile.h" | 34 #include "chrome/test/base/testing_profile.h" |
35 #include "chrome/test/base/ui_test_utils.h" | 35 #include "chrome/test/base/ui_test_utils.h" |
36 #include "chromeos/chromeos_switches.h" | 36 #include "chromeos/chromeos_switches.h" |
37 #include "chromeos/dbus/fake_session_manager_client.h" | 37 #include "chromeos/dbus/fake_session_manager_client.h" |
38 #include "chromeos/settings/cros_settings_names.h" | 38 #include "chromeos/settings/cros_settings_names.h" |
39 #include "components/policy/core/common/cloud/cloud_policy_constants.h" | 39 #include "components/policy/core/common/cloud/cloud_policy_constants.h" |
40 #include "components/policy/core/common/cloud/cloud_policy_core.h" | 40 #include "components/policy/core/common/cloud/cloud_policy_core.h" |
41 #include "components/policy/core/common/cloud/cloud_policy_store.h" | 41 #include "components/policy/core/common/cloud/cloud_policy_store.h" |
42 #include "components/policy/core/common/cloud/mock_cloud_policy_store.h" | 42 #include "components/policy/core/common/cloud/mock_cloud_policy_store.h" |
(...skipping 30 matching lines...) Expand all Loading... | |
73 const int kAutoLoginShortDelay = 1; | 73 const int kAutoLoginShortDelay = 1; |
74 const int kAutoLoginLongDelay = 10000; | 74 const int kAutoLoginLongDelay = 10000; |
75 | 75 |
76 | 76 |
77 ACTION_P2(CreateAuthenticator, username, password) { | 77 ACTION_P2(CreateAuthenticator, username, password) { |
78 return new MockAuthenticator(arg0, username, password); | 78 return new MockAuthenticator(arg0, username, password); |
79 } | 79 } |
80 | 80 |
81 } // namespace | 81 } // namespace |
82 | 82 |
83 class ExistingUserControllerTest : public policy::DevicePolicyCrosBrowserTest, | 83 class ExistingUserControllerTest : public policy::DevicePolicyCrosBrowserTest { |
84 public testing::WithParamInterface<bool> { | |
85 protected: | 84 protected: |
86 ExistingUserControllerTest() | 85 ExistingUserControllerTest() |
87 : mock_login_display_(NULL), mock_user_manager_(NULL) {} | 86 : mock_login_display_(NULL), mock_user_manager_(NULL) {} |
88 | 87 |
89 ExistingUserController* existing_user_controller() { | 88 ExistingUserController* existing_user_controller() { |
90 return ExistingUserController::current_controller(); | 89 return ExistingUserController::current_controller(); |
91 } | 90 } |
92 | 91 |
93 const ExistingUserController* existing_user_controller() const { | 92 const ExistingUserController* existing_user_controller() const { |
94 return ExistingUserController::current_controller(); | 93 return ExistingUserController::current_controller(); |
(...skipping 25 matching lines...) Expand all Loading... | |
120 .Times(1) | 119 .Times(1) |
121 .WillOnce(ReturnNull()); | 120 .WillOnce(ReturnNull()); |
122 EXPECT_CALL(*mock_login_display_host_.get(), OnPreferencesChanged()) | 121 EXPECT_CALL(*mock_login_display_host_.get(), OnPreferencesChanged()) |
123 .Times(1); | 122 .Times(1); |
124 EXPECT_CALL(*mock_login_display_, Init(_, false, true, true)) | 123 EXPECT_CALL(*mock_login_display_, Init(_, false, true, true)) |
125 .Times(1); | 124 .Times(1); |
126 } | 125 } |
127 | 126 |
128 virtual void SetUpCommandLine(CommandLine* command_line) OVERRIDE { | 127 virtual void SetUpCommandLine(CommandLine* command_line) OVERRIDE { |
129 command_line->AppendSwitch(switches::kLoginManager); | 128 command_line->AppendSwitch(switches::kLoginManager); |
130 if (GetParam()) | |
131 command_line->AppendSwitch(::switches::kMultiProfiles); | |
132 } | 129 } |
133 | 130 |
134 virtual void SetUpUserManager() { | 131 virtual void SetUpUserManager() { |
135 // Replace the UserManager singleton with a mock. | 132 // Replace the UserManager singleton with a mock. |
136 mock_user_manager_ = new MockUserManager; | 133 mock_user_manager_ = new MockUserManager; |
137 user_manager_enabler_.reset( | 134 user_manager_enabler_.reset( |
138 new ScopedUserManagerEnabler(mock_user_manager_)); | 135 new ScopedUserManagerEnabler(mock_user_manager_)); |
139 EXPECT_CALL(*mock_user_manager_, IsKnownUser(kUsername)) | 136 EXPECT_CALL(*mock_user_manager_, IsKnownUser(kUsername)) |
140 .Times(AnyNumber()) | 137 .Times(AnyNumber()) |
141 .WillRepeatedly(Return(true)); | 138 .WillRepeatedly(Return(true)); |
(...skipping 84 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
226 | 223 |
227 // Mock URLFetcher. | 224 // Mock URLFetcher. |
228 MockURLFetcherFactory<SuccessFetcher> factory_; | 225 MockURLFetcherFactory<SuccessFetcher> factory_; |
229 | 226 |
230 base::Callback<void(void)> profile_prepared_cb_; | 227 base::Callback<void(void)> profile_prepared_cb_; |
231 | 228 |
232 private: | 229 private: |
233 DISALLOW_COPY_AND_ASSIGN(ExistingUserControllerTest); | 230 DISALLOW_COPY_AND_ASSIGN(ExistingUserControllerTest); |
234 }; | 231 }; |
235 | 232 |
236 IN_PROC_BROWSER_TEST_P(ExistingUserControllerTest, ExistingUserLogin) { | 233 IN_PROC_BROWSER_TEST_F(ExistingUserControllerTest, ExistingUserLogin) { |
237 // This is disabled twice: once right after signin but before checking for | 234 // This is disabled twice: once right after signin but before checking for |
238 // auto-enrollment, and again after doing an ownership status check. | 235 // auto-enrollment, and again after doing an ownership status check. |
239 EXPECT_CALL(*mock_login_display_, SetUIEnabled(false)) | 236 EXPECT_CALL(*mock_login_display_, SetUIEnabled(false)) |
240 .Times(2); | 237 .Times(2); |
241 EXPECT_CALL(*mock_login_utils_, CreateAuthenticator(_)) | 238 EXPECT_CALL(*mock_login_utils_, CreateAuthenticator(_)) |
242 .Times(1) | 239 .Times(1) |
243 .WillOnce(WithArg<0>(CreateAuthenticator(kUsername, kPassword))); | 240 .WillOnce(WithArg<0>(CreateAuthenticator(kUsername, kPassword))); |
244 EXPECT_CALL(*mock_login_utils_, | 241 EXPECT_CALL(*mock_login_utils_, |
245 PrepareProfile(UserContext(kUsername, kPassword, "", kUsername), | 242 PrepareProfile(UserContext(kUsername, kPassword, "", kUsername), |
246 _, _, _, _)) | 243 _, _, _, _)) |
(...skipping 13 matching lines...) Expand all Loading... | |
260 EXPECT_CALL(*mock_login_display_host_, | 257 EXPECT_CALL(*mock_login_display_host_, |
261 StartWizardPtr(WizardController::kTermsOfServiceScreenName, NULL)) | 258 StartWizardPtr(WizardController::kTermsOfServiceScreenName, NULL)) |
262 .Times(0); | 259 .Times(0); |
263 EXPECT_CALL(*mock_user_manager_, IsCurrentUserNew()) | 260 EXPECT_CALL(*mock_user_manager_, IsCurrentUserNew()) |
264 .Times(AnyNumber()) | 261 .Times(AnyNumber()) |
265 .WillRepeatedly(Return(false)); | 262 .WillRepeatedly(Return(false)); |
266 existing_user_controller()->Login(UserContext(kUsername, kPassword, "")); | 263 existing_user_controller()->Login(UserContext(kUsername, kPassword, "")); |
267 content::RunAllPendingInMessageLoop(); | 264 content::RunAllPendingInMessageLoop(); |
268 } | 265 } |
269 | 266 |
270 IN_PROC_BROWSER_TEST_P(ExistingUserControllerTest, AutoEnrollAfterSignIn) { | 267 IN_PROC_BROWSER_TEST_F(ExistingUserControllerTest, AutoEnrollAfterSignIn) { |
271 EXPECT_CALL(*mock_login_display_host_, | 268 EXPECT_CALL(*mock_login_display_host_, |
272 StartWizardPtr(WizardController::kEnrollmentScreenName, | 269 StartWizardPtr(WizardController::kEnrollmentScreenName, |
273 _)) | 270 _)) |
274 .Times(1); | 271 .Times(1); |
275 EXPECT_CALL(*mock_login_display_, OnFadeOut()) | 272 EXPECT_CALL(*mock_login_display_, OnFadeOut()) |
276 .Times(1); | 273 .Times(1); |
277 EXPECT_CALL(*mock_login_display_host_.get(), OnCompleteLogin()) | 274 EXPECT_CALL(*mock_login_display_host_.get(), OnCompleteLogin()) |
278 .Times(1); | 275 .Times(1); |
279 EXPECT_CALL(*mock_user_manager_, IsCurrentUserNew()) | 276 EXPECT_CALL(*mock_user_manager_, IsCurrentUserNew()) |
280 .Times(AnyNumber()) | 277 .Times(AnyNumber()) |
281 .WillRepeatedly(Return(false)); | 278 .WillRepeatedly(Return(false)); |
282 // The order of these expected calls matters: the UI if first disabled | 279 // The order of these expected calls matters: the UI if first disabled |
283 // during the login sequence, and is enabled again for the enrollment screen. | 280 // during the login sequence, and is enabled again for the enrollment screen. |
284 Sequence uiEnabledSequence; | 281 Sequence uiEnabledSequence; |
285 EXPECT_CALL(*mock_login_display_, SetUIEnabled(false)) | 282 EXPECT_CALL(*mock_login_display_, SetUIEnabled(false)) |
286 .Times(1) | 283 .Times(1) |
287 .InSequence(uiEnabledSequence); | 284 .InSequence(uiEnabledSequence); |
288 EXPECT_CALL(*mock_login_display_, SetUIEnabled(true)) | 285 EXPECT_CALL(*mock_login_display_, SetUIEnabled(true)) |
289 .Times(1) | 286 .Times(1) |
290 .InSequence(uiEnabledSequence); | 287 .InSequence(uiEnabledSequence); |
291 existing_user_controller()->DoAutoEnrollment(); | 288 existing_user_controller()->DoAutoEnrollment(); |
292 existing_user_controller()->CompleteLogin( | 289 existing_user_controller()->CompleteLogin( |
293 UserContext(kUsername, kPassword, "")); | 290 UserContext(kUsername, kPassword, "")); |
294 content::RunAllPendingInMessageLoop(); | 291 content::RunAllPendingInMessageLoop(); |
295 } | 292 } |
296 | 293 |
297 IN_PROC_BROWSER_TEST_P(ExistingUserControllerTest, | 294 IN_PROC_BROWSER_TEST_F(ExistingUserControllerTest, |
298 NewUserDontAutoEnrollAfterSignIn) { | 295 NewUserDontAutoEnrollAfterSignIn) { |
299 EXPECT_CALL(*mock_login_display_host_, | 296 EXPECT_CALL(*mock_login_display_host_, |
300 StartWizardPtr(WizardController::kEnrollmentScreenName, | 297 StartWizardPtr(WizardController::kEnrollmentScreenName, |
301 _)) | 298 _)) |
302 .Times(0); | 299 .Times(0); |
303 EXPECT_CALL(*mock_login_display_host_, | 300 EXPECT_CALL(*mock_login_display_host_, |
304 StartWizardPtr(WizardController::kTermsOfServiceScreenName, | 301 StartWizardPtr(WizardController::kTermsOfServiceScreenName, |
305 NULL)) | 302 NULL)) |
306 .Times(1); | 303 .Times(1); |
307 EXPECT_CALL(*mock_login_utils_, CreateAuthenticator(_)) | 304 EXPECT_CALL(*mock_login_utils_, CreateAuthenticator(_)) |
(...skipping 209 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
517 void FireAutoLogin() { | 514 void FireAutoLogin() { |
518 existing_user_controller()->OnPublicSessionAutoLoginTimerFire(); | 515 existing_user_controller()->OnPublicSessionAutoLoginTimerFire(); |
519 } | 516 } |
520 | 517 |
521 const std::string public_session_user_id_; | 518 const std::string public_session_user_id_; |
522 | 519 |
523 private: | 520 private: |
524 DISALLOW_COPY_AND_ASSIGN(ExistingUserControllerPublicSessionTest); | 521 DISALLOW_COPY_AND_ASSIGN(ExistingUserControllerPublicSessionTest); |
525 }; | 522 }; |
526 | 523 |
527 IN_PROC_BROWSER_TEST_P(ExistingUserControllerPublicSessionTest, | 524 IN_PROC_BROWSER_TEST_F(ExistingUserControllerPublicSessionTest, |
528 ConfigureAutoLoginUsingPolicy) { | 525 ConfigureAutoLoginUsingPolicy) { |
529 existing_user_controller()->OnSigninScreenReady(); | 526 existing_user_controller()->OnSigninScreenReady(); |
530 EXPECT_EQ("", auto_login_username()); | 527 EXPECT_EQ("", auto_login_username()); |
531 EXPECT_EQ(0, auto_login_delay()); | 528 EXPECT_EQ(0, auto_login_delay()); |
532 EXPECT_FALSE(auto_login_timer()); | 529 EXPECT_FALSE(auto_login_timer()); |
533 | 530 |
534 // Set the policy. | 531 // Set the policy. |
535 SetAutoLoginPolicy(kPublicSessionAccountId, kAutoLoginLongDelay); | 532 SetAutoLoginPolicy(kPublicSessionAccountId, kAutoLoginLongDelay); |
536 EXPECT_EQ(public_session_user_id_, auto_login_username()); | 533 EXPECT_EQ(public_session_user_id_, auto_login_username()); |
537 EXPECT_EQ(kAutoLoginLongDelay, auto_login_delay()); | 534 EXPECT_EQ(kAutoLoginLongDelay, auto_login_delay()); |
538 ASSERT_TRUE(auto_login_timer()); | 535 ASSERT_TRUE(auto_login_timer()); |
539 EXPECT_TRUE(auto_login_timer()->IsRunning()); | 536 EXPECT_TRUE(auto_login_timer()->IsRunning()); |
540 | 537 |
541 // Unset the policy. | 538 // Unset the policy. |
542 SetAutoLoginPolicy("", 0); | 539 SetAutoLoginPolicy("", 0); |
543 EXPECT_EQ("", auto_login_username()); | 540 EXPECT_EQ("", auto_login_username()); |
544 EXPECT_EQ(0, auto_login_delay()); | 541 EXPECT_EQ(0, auto_login_delay()); |
545 ASSERT_TRUE(auto_login_timer()); | 542 ASSERT_TRUE(auto_login_timer()); |
546 EXPECT_FALSE(auto_login_timer()->IsRunning()); | 543 EXPECT_FALSE(auto_login_timer()->IsRunning()); |
547 } | 544 } |
548 | 545 |
549 IN_PROC_BROWSER_TEST_P(ExistingUserControllerPublicSessionTest, | 546 IN_PROC_BROWSER_TEST_F(ExistingUserControllerPublicSessionTest, |
550 AutoLoginNoDelay) { | 547 AutoLoginNoDelay) { |
551 // Set up mocks to check login success. | 548 // Set up mocks to check login success. |
552 ExpectSuccessfulLogin(public_session_user_id_, ""); | 549 ExpectSuccessfulLogin(public_session_user_id_, ""); |
553 existing_user_controller()->OnSigninScreenReady(); | 550 existing_user_controller()->OnSigninScreenReady(); |
554 | 551 |
555 // Start auto-login and wait for login tasks to complete. | 552 // Start auto-login and wait for login tasks to complete. |
556 SetAutoLoginPolicy(kPublicSessionAccountId, kAutoLoginNoDelay); | 553 SetAutoLoginPolicy(kPublicSessionAccountId, kAutoLoginNoDelay); |
557 content::RunAllPendingInMessageLoop(); | 554 content::RunAllPendingInMessageLoop(); |
558 } | 555 } |
559 | 556 |
560 IN_PROC_BROWSER_TEST_P(ExistingUserControllerPublicSessionTest, | 557 IN_PROC_BROWSER_TEST_F(ExistingUserControllerPublicSessionTest, |
561 AutoLoginShortDelay) { | 558 AutoLoginShortDelay) { |
562 // Set up mocks to check login success. | 559 // Set up mocks to check login success. |
563 ExpectSuccessfulLogin(public_session_user_id_, ""); | 560 ExpectSuccessfulLogin(public_session_user_id_, ""); |
564 existing_user_controller()->OnSigninScreenReady(); | 561 existing_user_controller()->OnSigninScreenReady(); |
565 SetAutoLoginPolicy(kPublicSessionAccountId, kAutoLoginShortDelay); | 562 SetAutoLoginPolicy(kPublicSessionAccountId, kAutoLoginShortDelay); |
566 ASSERT_TRUE(auto_login_timer()); | 563 ASSERT_TRUE(auto_login_timer()); |
567 // Don't assert that timer is running: with the short delay sometimes | 564 // Don't assert that timer is running: with the short delay sometimes |
568 // the trigger happens before the assert. We've already tested that | 565 // the trigger happens before the assert. We've already tested that |
569 // the timer starts when it should. | 566 // the timer starts when it should. |
570 | 567 |
571 // Wait for the timer to fire. | 568 // Wait for the timer to fire. |
572 base::RunLoop runner; | 569 base::RunLoop runner; |
573 base::OneShotTimer<base::RunLoop> timer; | 570 base::OneShotTimer<base::RunLoop> timer; |
574 timer.Start(FROM_HERE, | 571 timer.Start(FROM_HERE, |
575 base::TimeDelta::FromMilliseconds(kAutoLoginShortDelay + 1), | 572 base::TimeDelta::FromMilliseconds(kAutoLoginShortDelay + 1), |
576 runner.QuitClosure()); | 573 runner.QuitClosure()); |
577 runner.Run(); | 574 runner.Run(); |
578 | 575 |
579 // Wait for login tasks to complete. | 576 // Wait for login tasks to complete. |
580 content::RunAllPendingInMessageLoop(); | 577 content::RunAllPendingInMessageLoop(); |
581 } | 578 } |
582 | 579 |
583 IN_PROC_BROWSER_TEST_P(ExistingUserControllerPublicSessionTest, | 580 IN_PROC_BROWSER_TEST_F(ExistingUserControllerPublicSessionTest, |
584 LoginStopsAutoLogin) { | 581 LoginStopsAutoLogin) { |
585 // Set up mocks to check login success. | 582 // Set up mocks to check login success. |
586 ExpectSuccessfulLogin(kUsername, kPassword); | 583 ExpectSuccessfulLogin(kUsername, kPassword); |
587 | 584 |
588 existing_user_controller()->OnSigninScreenReady(); | 585 existing_user_controller()->OnSigninScreenReady(); |
589 SetAutoLoginPolicy(kPublicSessionAccountId, kAutoLoginLongDelay); | 586 SetAutoLoginPolicy(kPublicSessionAccountId, kAutoLoginLongDelay); |
590 ASSERT_TRUE(auto_login_timer()); | 587 ASSERT_TRUE(auto_login_timer()); |
591 | 588 |
592 // Login and check that it stopped the timer. | 589 // Login and check that it stopped the timer. |
593 existing_user_controller()->Login(UserContext(kUsername, kPassword, "")); | 590 existing_user_controller()->Login(UserContext(kUsername, kPassword, "")); |
594 EXPECT_TRUE(is_login_in_progress()); | 591 EXPECT_TRUE(is_login_in_progress()); |
595 ASSERT_TRUE(auto_login_timer()); | 592 ASSERT_TRUE(auto_login_timer()); |
596 EXPECT_FALSE(auto_login_timer()->IsRunning()); | 593 EXPECT_FALSE(auto_login_timer()->IsRunning()); |
597 | 594 |
598 // Wait for login tasks to complete. | 595 // Wait for login tasks to complete. |
599 content::RunAllPendingInMessageLoop(); | 596 content::RunAllPendingInMessageLoop(); |
600 | 597 |
601 // Timer should still be stopped after login completes. | 598 // Timer should still be stopped after login completes. |
602 ASSERT_TRUE(auto_login_timer()); | 599 ASSERT_TRUE(auto_login_timer()); |
603 EXPECT_FALSE(auto_login_timer()->IsRunning()); | 600 EXPECT_FALSE(auto_login_timer()->IsRunning()); |
604 } | 601 } |
605 | 602 |
606 IN_PROC_BROWSER_TEST_P(ExistingUserControllerPublicSessionTest, | 603 IN_PROC_BROWSER_TEST_F(ExistingUserControllerPublicSessionTest, |
607 GuestModeLoginStopsAutoLogin) { | 604 GuestModeLoginStopsAutoLogin) { |
608 EXPECT_CALL(*mock_login_display_, SetUIEnabled(false)) | 605 EXPECT_CALL(*mock_login_display_, SetUIEnabled(false)) |
609 .Times(1); | 606 .Times(1); |
610 EXPECT_CALL(*mock_login_utils_, CreateAuthenticator(_)) | 607 EXPECT_CALL(*mock_login_utils_, CreateAuthenticator(_)) |
611 .Times(1) | 608 .Times(1) |
612 .WillOnce(WithArg<0>(CreateAuthenticator(kUsername, kPassword))); | 609 .WillOnce(WithArg<0>(CreateAuthenticator(kUsername, kPassword))); |
613 EXPECT_CALL(*mock_login_utils_, CompleteOffTheRecordLogin(_)) | 610 EXPECT_CALL(*mock_login_utils_, CompleteOffTheRecordLogin(_)) |
614 .Times(1); | 611 .Times(1); |
615 | 612 |
616 existing_user_controller()->OnSigninScreenReady(); | 613 existing_user_controller()->OnSigninScreenReady(); |
617 SetAutoLoginPolicy(kPublicSessionAccountId, kAutoLoginLongDelay); | 614 SetAutoLoginPolicy(kPublicSessionAccountId, kAutoLoginLongDelay); |
618 ASSERT_TRUE(auto_login_timer()); | 615 ASSERT_TRUE(auto_login_timer()); |
619 | 616 |
620 // Login and check that it stopped the timer. | 617 // Login and check that it stopped the timer. |
621 existing_user_controller()->LoginAsGuest(); | 618 existing_user_controller()->LoginAsGuest(); |
622 EXPECT_TRUE(is_login_in_progress()); | 619 EXPECT_TRUE(is_login_in_progress()); |
623 ASSERT_TRUE(auto_login_timer()); | 620 ASSERT_TRUE(auto_login_timer()); |
624 EXPECT_FALSE(auto_login_timer()->IsRunning()); | 621 EXPECT_FALSE(auto_login_timer()->IsRunning()); |
625 | 622 |
626 // Wait for login tasks to complete. | 623 // Wait for login tasks to complete. |
627 content::RunAllPendingInMessageLoop(); | 624 content::RunAllPendingInMessageLoop(); |
628 | 625 |
629 // Timer should still be stopped after login completes. | 626 // Timer should still be stopped after login completes. |
630 ASSERT_TRUE(auto_login_timer()); | 627 ASSERT_TRUE(auto_login_timer()); |
631 EXPECT_FALSE(auto_login_timer()->IsRunning()); | 628 EXPECT_FALSE(auto_login_timer()->IsRunning()); |
632 } | 629 } |
633 | 630 |
634 IN_PROC_BROWSER_TEST_P(ExistingUserControllerPublicSessionTest, | 631 IN_PROC_BROWSER_TEST_F(ExistingUserControllerPublicSessionTest, |
635 CompleteLoginStopsAutoLogin) { | 632 CompleteLoginStopsAutoLogin) { |
636 // Set up mocks to check login success. | 633 // Set up mocks to check login success. |
637 ExpectSuccessfulLogin(kUsername, kPassword); | 634 ExpectSuccessfulLogin(kUsername, kPassword); |
638 EXPECT_CALL(*mock_login_display_host_, OnCompleteLogin()) | 635 EXPECT_CALL(*mock_login_display_host_, OnCompleteLogin()) |
639 .Times(1); | 636 .Times(1); |
640 | 637 |
641 existing_user_controller()->OnSigninScreenReady(); | 638 existing_user_controller()->OnSigninScreenReady(); |
642 SetAutoLoginPolicy(kPublicSessionAccountId, kAutoLoginLongDelay); | 639 SetAutoLoginPolicy(kPublicSessionAccountId, kAutoLoginLongDelay); |
643 ASSERT_TRUE(auto_login_timer()); | 640 ASSERT_TRUE(auto_login_timer()); |
644 | 641 |
645 // Check that login completes and stops the timer. | 642 // Check that login completes and stops the timer. |
646 existing_user_controller()->CompleteLogin( | 643 existing_user_controller()->CompleteLogin( |
647 UserContext(kUsername, kPassword, "")); | 644 UserContext(kUsername, kPassword, "")); |
648 ASSERT_TRUE(auto_login_timer()); | 645 ASSERT_TRUE(auto_login_timer()); |
649 EXPECT_FALSE(auto_login_timer()->IsRunning()); | 646 EXPECT_FALSE(auto_login_timer()->IsRunning()); |
650 | 647 |
651 // Wait for login tasks to complete. | 648 // Wait for login tasks to complete. |
652 content::RunAllPendingInMessageLoop(); | 649 content::RunAllPendingInMessageLoop(); |
653 | 650 |
654 // Timer should still be stopped after login completes. | 651 // Timer should still be stopped after login completes. |
655 ASSERT_TRUE(auto_login_timer()); | 652 ASSERT_TRUE(auto_login_timer()); |
656 EXPECT_FALSE(auto_login_timer()->IsRunning()); | 653 EXPECT_FALSE(auto_login_timer()->IsRunning()); |
657 } | 654 } |
658 | 655 |
659 IN_PROC_BROWSER_TEST_P(ExistingUserControllerPublicSessionTest, | 656 IN_PROC_BROWSER_TEST_F(ExistingUserControllerPublicSessionTest, |
660 PublicSessionLoginStopsAutoLogin) { | 657 PublicSessionLoginStopsAutoLogin) { |
661 // Set up mocks to check login success. | 658 // Set up mocks to check login success. |
662 ExpectSuccessfulLogin(public_session_user_id_, ""); | 659 ExpectSuccessfulLogin(public_session_user_id_, ""); |
663 existing_user_controller()->OnSigninScreenReady(); | 660 existing_user_controller()->OnSigninScreenReady(); |
664 SetAutoLoginPolicy(kPublicSessionAccountId, kAutoLoginLongDelay); | 661 SetAutoLoginPolicy(kPublicSessionAccountId, kAutoLoginLongDelay); |
665 ASSERT_TRUE(auto_login_timer()); | 662 ASSERT_TRUE(auto_login_timer()); |
666 | 663 |
667 // Login and check that it stopped the timer. | 664 // Login and check that it stopped the timer. |
668 existing_user_controller()->LoginAsPublicAccount(public_session_user_id_); | 665 existing_user_controller()->LoginAsPublicAccount(public_session_user_id_); |
669 EXPECT_TRUE(is_login_in_progress()); | 666 EXPECT_TRUE(is_login_in_progress()); |
670 ASSERT_TRUE(auto_login_timer()); | 667 ASSERT_TRUE(auto_login_timer()); |
671 EXPECT_FALSE(auto_login_timer()->IsRunning()); | 668 EXPECT_FALSE(auto_login_timer()->IsRunning()); |
672 | 669 |
673 // Wait for login tasks to complete. | 670 // Wait for login tasks to complete. |
674 content::RunAllPendingInMessageLoop(); | 671 content::RunAllPendingInMessageLoop(); |
675 | 672 |
676 // Timer should still be stopped after login completes. | 673 // Timer should still be stopped after login completes. |
677 ASSERT_TRUE(auto_login_timer()); | 674 ASSERT_TRUE(auto_login_timer()); |
678 EXPECT_FALSE(auto_login_timer()->IsRunning()); | 675 EXPECT_FALSE(auto_login_timer()->IsRunning()); |
679 } | 676 } |
680 | 677 |
681 IN_PROC_BROWSER_TEST_P(ExistingUserControllerPublicSessionTest, | 678 IN_PROC_BROWSER_TEST_F(ExistingUserControllerPublicSessionTest, |
682 PRE_TestLoadingPublicUsersFromLocalState) { | 679 PRE_TestLoadingPublicUsersFromLocalState) { |
683 // First run propagates public accounts and stores them in Local State. | 680 // First run propagates public accounts and stores them in Local State. |
684 } | 681 } |
685 | 682 |
686 IN_PROC_BROWSER_TEST_P(ExistingUserControllerPublicSessionTest, | 683 IN_PROC_BROWSER_TEST_F(ExistingUserControllerPublicSessionTest, |
687 TestLoadingPublicUsersFromLocalState) { | 684 TestLoadingPublicUsersFromLocalState) { |
688 // Second run loads list of public accounts from Local State. | 685 // Second run loads list of public accounts from Local State. |
689 } | 686 } |
690 | 687 |
691 INSTANTIATE_TEST_CASE_P(ExistingUserControllerTestInstantiation, | |
692 ExistingUserControllerTest, | |
693 testing::Bool()); | |
694 | |
695 INSTANTIATE_TEST_CASE_P(ExistingUserControllerPublicSessionTestInstantiation, | |
696 ExistingUserControllerPublicSessionTest, | |
697 testing::Bool()); | |
698 | |
699 } // namespace chromeos | 688 } // namespace chromeos |
OLD | NEW |