Chromium Code Reviews

Side by Side Diff: chrome/browser/chromeos/login/existing_user_controller_auto_login_unittest.cc

Issue 12218078: Implement a policy to autologin a public account. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: more nits Created 7 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
View unified diff | | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "base/memory/scoped_ptr.h"
bartfab (slow) 2013/03/07 12:17:23 This is included by "existing_user_controller.h" a
dconnelly 2013/03/07 14:45:19 Done.
6 #include "base/message_loop.h"
7 #include "chrome/browser/chromeos/login/existing_user_controller.h"
8 #include "chrome/browser/chromeos/login/login_display.h"
bartfab (slow) 2013/03/07 12:17:23 This is not used.
dconnelly 2013/03/07 14:45:19 Done.
9 #include "chrome/browser/chromeos/login/login_display_host.h"
bartfab (slow) 2013/03/07 12:17:23 This is not used.
dconnelly 2013/03/07 14:45:19 Done.
10 #include "chrome/browser/chromeos/login/login_utils.h"
bartfab (slow) 2013/03/07 12:17:23 This is included by "existing_user_controller.h" a
dconnelly 2013/03/07 14:45:19 Done.
11 #include "chrome/browser/chromeos/login/mock_login_display.h"
12 #include "chrome/browser/chromeos/login/mock_login_display_host.h"
13 #include "chrome/browser/chromeos/login/mock_login_utils.h"
14 #include "chrome/browser/chromeos/settings/cros_settings.h"
15 #include "chrome/browser/chromeos/settings/device_settings_test_helper.h"
16 #include "chrome/test/base/scoped_testing_local_state.h"
17 #include "chrome/test/base/testing_browser_process.h"
18 #include "content/public/test/test_browser_thread.h"
19 #include "testing/gmock/include/gmock/gmock.h"
20 #include "testing/gtest/include/gtest/gtest.h"
21
22 using testing::AnyNumber;
bartfab (slow) 2013/03/07 12:17:23 This is not used.
dconnelly 2013/03/07 14:45:19 Done.
23 using testing::AtLeast;
bartfab (slow) 2013/03/07 12:17:23 This is not used.
dconnelly 2013/03/07 14:45:19 Done.
24 using testing::Mock;
bartfab (slow) 2013/03/07 12:17:23 This is not used.
dconnelly 2013/03/07 14:45:19 Done.
25 using testing::Return;
26 using testing::ReturnNull;
bartfab (slow) 2013/03/07 12:17:23 This is not used.
dconnelly 2013/03/07 14:45:19 Done.
27 using testing::SaveArg;
bartfab (slow) 2013/03/07 12:17:23 This is not used.
dconnelly 2013/03/07 14:45:19 Done.
28 using testing::_;
29
30 namespace chromeos {
31
32 namespace {
33
34 const char kAutoLoginUsername[] = "public_session_user@localhost";
35 const int kAutoLoginNoDelay = 0;
bartfab (slow) 2013/03/07 12:17:23 This is not used anywhere.
dconnelly 2013/03/07 14:45:19 Done.
36 const int kAutoLoginShortDelay = 1;
bartfab (slow) 2013/03/07 12:17:23 Nit: Add an "Ms" suffix to make it clear that this
dconnelly 2013/03/07 14:45:19 Done.
37 const int kAutoLoginLongDelay = 10000;
bartfab (slow) 2013/03/07 12:17:23 Nit: Add an "Ms" suffix to make it clear that this
dconnelly 2013/03/07 14:45:19 Done.
38
39 } // namespace
40
41 class ExistingUserControllerAutoLoginTest : public ::testing::Test {
42 protected:
43 ExistingUserControllerAutoLoginTest()
44 : message_loop_(MessageLoop::TYPE_UI),
45 ui_thread_(content::BrowserThread::UI, &message_loop_),
46 local_state_(TestingBrowserProcess::GetGlobal()) {
47 }
48
49 virtual void SetUp() {
50 mock_login_display_host_.reset(new MockLoginDisplayHost);
51 mock_login_display_ = new MockLoginDisplay();
52 mock_login_utils_ = new MockLoginUtils();
53 LoginUtils::Set(mock_login_utils_);
54
55 EXPECT_CALL(*mock_login_display_host_.get(), CreateLoginDisplay(_))
56 .Times(1)
57 .WillOnce(Return(mock_login_display_));
58
59 existing_user_controller_.reset(
60 new ExistingUserController(mock_login_display_host_.get()));
61
62 CrosSettings::Get()->RemoveSettingsObserver(
bartfab (slow) 2013/03/07 12:17:23 Why do you not want the ExistingUserController to
dconnelly 2013/03/07 14:45:19 Done.
63 kAccountsPrefDeviceLocalAccountAutoLoginId,
bartfab (slow) 2013/03/07 12:17:23 #include "chrome/browser/chromeos/settings/cros_se
dconnelly 2013/03/07 14:45:19 Done.
64 existing_user_controller());
65 CrosSettings::Get()->RemoveSettingsObserver(
66 kAccountsPrefDeviceLocalAccountAutoLoginDelay,
67 existing_user_controller());
68 }
69
70 ExistingUserController* existing_user_controller() {
71 return ExistingUserController::current_controller();
72 }
73
74 void SetAutoLoginSettings(const std::string& username, int delay) {
75 CrosSettings::Get()->SetString(
76 kAccountsPrefDeviceLocalAccountAutoLoginId,
77 username);
78 CrosSettings::Get()->SetInteger(
79 kAccountsPrefDeviceLocalAccountAutoLoginDelay,
80 delay);
81 }
82
83 // ExistingUserController private member accessors.
84 base::OneShotTimer<ExistingUserController>* auto_login_timer() {
85 return existing_user_controller()->auto_login_timer_.get();
86 }
87
88 std::string auto_login_username() {
bartfab (slow) 2013/03/07 12:17:23 Nit: const Nit: Return const std::string&
dconnelly 2013/03/07 14:45:19 Done.
89 return existing_user_controller()->public_session_auto_login_username_;
90 }
91 void set_auto_login_username(const std::string& username) {
92 existing_user_controller()->public_session_auto_login_username_ = username;
93 }
94
95 int auto_login_delay() {
bartfab (slow) 2013/03/07 12:17:23 Nit: const
dconnelly 2013/03/07 14:45:19 Done.
96 return existing_user_controller()->public_session_auto_login_delay_;
97 }
98 void set_auto_login_delay(int delay) {
99 existing_user_controller()->public_session_auto_login_delay_ = delay;
100 }
101
102 bool is_login_in_progress() {
bartfab (slow) 2013/03/07 12:17:23 Nit: const
dconnelly 2013/03/07 14:45:19 Done.
103 return existing_user_controller()->is_login_in_progress_;
104 }
105 void set_is_login_in_progress(bool is_login_in_progress) {
106 existing_user_controller()->is_login_in_progress_ = is_login_in_progress;
107 }
108
109 void ConfigureAutoLogin() {
110 existing_user_controller()->ConfigurePublicSessionAutoLogin();
111 }
112
113 private:
114 // Owned by LoginUtilsWrapper
bartfab (slow) 2013/03/07 12:17:23 Nit: Period at the end of the line.
dconnelly 2013/03/07 14:45:19 Done.
115 MockLoginUtils* mock_login_utils_;
116
117 // |mock_login_display_| is owned by the ExistingUserController, which calls
118 // CreateLoginDisplay() on the |mock_login_display_host_| to get it.
119 MockLoginDisplay* mock_login_display_;
120
121 scoped_ptr<MockLoginDisplayHost> mock_login_display_host_;
122 scoped_ptr<ExistingUserController> existing_user_controller_;
123 MessageLoop message_loop_;
124 content::TestBrowserThread ui_thread_;
125 ScopedTestingLocalState local_state_;
126 ScopedDeviceSettingsTestHelper device_settings_test_helper_;
127 };
128
129 TEST_F(ExistingUserControllerAutoLoginTest, StartAutoLoginTimer) {
130 // Timer shouldn't start until signin screen is ready.
131 set_auto_login_username(kAutoLoginUsername);
132 set_auto_login_delay(kAutoLoginLongDelay);
133 existing_user_controller()->StartPublicSessionAutoLoginTimer();
134 EXPECT_FALSE(auto_login_timer());
135
136 // Timer shouldn't start if the policy isn't set.
137 set_auto_login_username("");
138 existing_user_controller()->OnSigninScreenReady();
139 existing_user_controller()->StartPublicSessionAutoLoginTimer();
140 EXPECT_FALSE(auto_login_timer());
141
142 // Timer shouldn't fire in the middle of a login attempt.
143 set_auto_login_username(kAutoLoginUsername);
144 set_is_login_in_progress(true);
145 existing_user_controller()->StartPublicSessionAutoLoginTimer();
146 EXPECT_FALSE(auto_login_timer());
147
148 // Otherwise start.
149 set_is_login_in_progress(false);
150 existing_user_controller()->StartPublicSessionAutoLoginTimer();
151 ASSERT_TRUE(auto_login_timer());
152 EXPECT_TRUE(auto_login_timer()->IsRunning());
153 EXPECT_EQ(auto_login_timer()->GetCurrentDelay().InMilliseconds(),
154 kAutoLoginLongDelay);
155 }
156
157 TEST_F(ExistingUserControllerAutoLoginTest, StopAutoLoginTimer) {
158 existing_user_controller()->OnSigninScreenReady();
159 set_auto_login_username(kAutoLoginUsername);
160 set_auto_login_delay(kAutoLoginLongDelay);
161
162 existing_user_controller()->StartPublicSessionAutoLoginTimer();
163 ASSERT_TRUE(auto_login_timer());
164 EXPECT_TRUE(auto_login_timer()->IsRunning());
165
166 existing_user_controller()->StopPublicSessionAutoLoginTimer();
167 ASSERT_TRUE(auto_login_timer());
168 EXPECT_FALSE(auto_login_timer()->IsRunning());
169 }
170
171 TEST_F(ExistingUserControllerAutoLoginTest, ResetAutoLoginTimer) {
172 existing_user_controller()->OnSigninScreenReady();
173 set_auto_login_username(kAutoLoginUsername);
174
175 // Timer starts off not running.
176 EXPECT_FALSE(auto_login_timer());
177
178 // When the timer isn't running, nothing should happen.
179 existing_user_controller()->ResetPublicSessionAutoLoginTimer();
180 EXPECT_FALSE(auto_login_timer());
181
182 // Start the timer.
183 set_auto_login_delay(kAutoLoginLongDelay);
184 existing_user_controller()->StartPublicSessionAutoLoginTimer();
185 ASSERT_TRUE(auto_login_timer());
186 EXPECT_TRUE(auto_login_timer()->IsRunning());
187 EXPECT_EQ(auto_login_timer()->GetCurrentDelay().InMilliseconds(),
188 kAutoLoginLongDelay);
189
190 // User activity should restart the timer, so check to see that the
191 // timer delay was modified.
192 set_auto_login_delay(kAutoLoginShortDelay);
193 existing_user_controller()->ResetPublicSessionAutoLoginTimer();
194 ASSERT_TRUE(auto_login_timer());
195 EXPECT_TRUE(auto_login_timer()->IsRunning());
196 EXPECT_EQ(auto_login_timer()->GetCurrentDelay().InMilliseconds(),
197 kAutoLoginShortDelay);
198 }
199
200 TEST_F(ExistingUserControllerAutoLoginTest, ConfigureAutoLogin) {
201 existing_user_controller()->OnSigninScreenReady();
202
203 // Timer shouldn't start when the policy is disabled.
bartfab (slow) 2013/03/07 12:17:23 You are not really disabling the policy here, you
dconnelly 2013/03/07 14:45:19 Yes. This is redundant. It seemed more clear to do
204 SetAutoLoginSettings("", 0);
bartfab (slow) 2013/03/07 12:17:23 Nit: Use kAutoLoginNoDelay
dconnelly 2013/03/07 14:45:19 Done.
205 ConfigureAutoLogin();
206 EXPECT_FALSE(auto_login_timer());
207 EXPECT_EQ(auto_login_delay(), 0);
bartfab (slow) 2013/03/07 12:17:23 Nit: Use kAutoLoginNoDelay
dconnelly 2013/03/07 14:45:19 Done.
208 EXPECT_EQ(auto_login_username(), "");
209
210 // Timer shouldn't start when the delay alone is set.
211 SetAutoLoginSettings("", kAutoLoginShortDelay);
212 ConfigureAutoLogin();
213 EXPECT_FALSE(auto_login_timer());
214 EXPECT_EQ(auto_login_delay(), kAutoLoginShortDelay);
215 EXPECT_EQ(auto_login_username(), "");
216
217 // Timer should start when the username is set.
218 SetAutoLoginSettings(kAutoLoginUsername, kAutoLoginShortDelay);
219 ConfigureAutoLogin();
220 ASSERT_TRUE(auto_login_timer());
221 EXPECT_TRUE(auto_login_timer()->IsRunning());
222 EXPECT_EQ(auto_login_timer()->GetCurrentDelay().InMilliseconds(),
223 kAutoLoginShortDelay);
224 EXPECT_EQ(auto_login_delay(), kAutoLoginShortDelay);
225 EXPECT_EQ(auto_login_username(), kAutoLoginUsername);
226
227 // Timer should restart when the delay is changed.
228 SetAutoLoginSettings(kAutoLoginUsername, kAutoLoginLongDelay);
229 ConfigureAutoLogin();
230 ASSERT_TRUE(auto_login_timer());
231 EXPECT_TRUE(auto_login_timer()->IsRunning());
232 EXPECT_EQ(auto_login_timer()->GetCurrentDelay().InMilliseconds(),
233 kAutoLoginLongDelay);
234 EXPECT_EQ(auto_login_delay(), kAutoLoginLongDelay);
235 EXPECT_EQ(auto_login_username(), kAutoLoginUsername);
236
237 // Timer should stop when the username is unset.
238 SetAutoLoginSettings("", kAutoLoginLongDelay);
239 ConfigureAutoLogin();
240 ASSERT_TRUE(auto_login_timer());
241 EXPECT_FALSE(auto_login_timer()->IsRunning());
242 EXPECT_EQ(auto_login_timer()->GetCurrentDelay().InMilliseconds(),
243 kAutoLoginLongDelay);
244 EXPECT_EQ(auto_login_username(), "");
245 EXPECT_EQ(auto_login_delay(), kAutoLoginLongDelay);
246 }
247
248 } // namespace chromeos
OLDNEW

Powered by Google App Engine