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

Side by Side Diff: chromeos/login/login_state_unittest.cc

Issue 23444061: Test that LoginState observer triggers when only user type changes (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: a spelling error Created 7 years, 3 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 unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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 "chromeos/login/login_state.h" 5 #include "chromeos/login/login_state.h"
6 6
7 #include "base/command_line.h" 7 #include "base/command_line.h"
8 #include "base/compiler_specific.h" 8 #include "base/compiler_specific.h"
9 #include "base/message_loop/message_loop.h"
10 #include "chromeos/chromeos_switches.h" 9 #include "chromeos/chromeos_switches.h"
11 #include "chromeos/dbus/dbus_thread_manager.h"
12 #include "testing/gtest/include/gtest/gtest.h" 10 #include "testing/gtest/include/gtest/gtest.h"
13 11
14 namespace chromeos { 12 namespace chromeos {
15 13
16 class LoginStateTest : public testing::Test, 14 class LoginStateTest : public testing::Test,
17 public LoginState::Observer { 15 public LoginState::Observer {
18 public: 16 public:
19 LoginStateTest() : logged_in_user_type_(LoginState::LOGGED_IN_USER_NONE), 17 LoginStateTest() : logged_in_user_type_(LoginState::LOGGED_IN_USER_NONE),
20 login_state_changes_count_(0) { 18 login_state_changes_count_(0) {
21 } 19 }
22 virtual ~LoginStateTest() { 20 virtual ~LoginStateTest() {
23 } 21 }
24 22
25 // testing::Test 23 // testing::Test
26 virtual void SetUp() OVERRIDE { 24 virtual void SetUp() OVERRIDE {
27 CommandLine::ForCurrentProcess()->AppendSwitch(switches::kLoginManager); 25 CommandLine::ForCurrentProcess()->AppendSwitch(switches::kLoginManager);
28 // Initialize DBusThreadManager with a stub implementation.
29 DBusThreadManager::InitializeWithStub();
30 LoginState::Initialize(); 26 LoginState::Initialize();
31 LoginState::Get()->AddObserver(this); 27 LoginState::Get()->AddObserver(this);
32 } 28 }
33 29
34 virtual void TearDown() OVERRIDE { 30 virtual void TearDown() OVERRIDE {
35 LoginState::Get()->RemoveObserver(this); 31 LoginState::Get()->RemoveObserver(this);
36 LoginState::Shutdown(); 32 LoginState::Shutdown();
37 DBusThreadManager::Shutdown();
38 } 33 }
39 34
40 // LoginState::Observer 35 // LoginState::Observer
41 virtual void LoggedInStateChanged() OVERRIDE { 36 virtual void LoggedInStateChanged() OVERRIDE {
42 ++login_state_changes_count_; 37 ++login_state_changes_count_;
43 logged_in_user_type_ = LoginState::Get()->GetLoggedInUserType(); 38 logged_in_user_type_ = LoginState::Get()->GetLoggedInUserType();
44 } 39 }
45 40
46 protected: 41 protected:
47 // Returns number of times the login state changed since the last call to 42 // Returns number of times the login state changed since the last call to
48 // this method. 43 // this method.
49 unsigned int GetNewLoginStateChangesCount() { 44 unsigned int GetNewLoginStateChangesCount() {
50 unsigned int result = login_state_changes_count_; 45 unsigned int result = login_state_changes_count_;
51 login_state_changes_count_ = 0; 46 login_state_changes_count_ = 0;
52 return result; 47 return result;
53 } 48 }
54 49
55 base::MessageLoopForUI message_loop_;
56 LoginState::LoggedInUserType logged_in_user_type_; 50 LoginState::LoggedInUserType logged_in_user_type_;
57 51
58 private: 52 private:
59 unsigned int login_state_changes_count_; 53 unsigned int login_state_changes_count_;
60 54
61 DISALLOW_COPY_AND_ASSIGN(LoginStateTest); 55 DISALLOW_COPY_AND_ASSIGN(LoginStateTest);
62 }; 56 };
63 57
64 TEST_F(LoginStateTest, TestLoginState) { 58 TEST_F(LoginStateTest, TestLoginState) {
65 EXPECT_FALSE(LoginState::Get()->IsUserLoggedIn()); 59 EXPECT_FALSE(LoginState::Get()->IsUserLoggedIn());
66 EXPECT_FALSE(LoginState::Get()->IsInSafeMode()); 60 EXPECT_FALSE(LoginState::Get()->IsInSafeMode());
67 EXPECT_EQ(LoginState::LOGGED_IN_USER_NONE, logged_in_user_type_); 61 EXPECT_EQ(LoginState::LOGGED_IN_USER_NONE, logged_in_user_type_);
68 EXPECT_EQ(LoginState::LOGGED_IN_USER_NONE, 62 EXPECT_EQ(LoginState::LOGGED_IN_USER_NONE,
69 LoginState::Get()->GetLoggedInUserType()); 63 LoginState::Get()->GetLoggedInUserType());
70 64
71 // Setting login state to ACTIVE. 65 // Setting login state to ACTIVE.
72 LoginState::Get()->SetLoggedInState(LoginState::LOGGED_IN_ACTIVE, 66 LoginState::Get()->SetLoggedInState(LoginState::LOGGED_IN_ACTIVE,
73 LoginState::LOGGED_IN_USER_REGULAR); 67 LoginState::LOGGED_IN_USER_REGULAR);
74 EXPECT_EQ(LoginState::LOGGED_IN_USER_REGULAR, 68 EXPECT_EQ(LoginState::LOGGED_IN_USER_REGULAR,
75 LoginState::Get()->GetLoggedInUserType()); 69 LoginState::Get()->GetLoggedInUserType());
76 EXPECT_TRUE(LoginState::Get()->IsUserLoggedIn()); 70 EXPECT_TRUE(LoginState::Get()->IsUserLoggedIn());
77 EXPECT_FALSE(LoginState::Get()->IsInSafeMode()); 71 EXPECT_FALSE(LoginState::Get()->IsInSafeMode());
78 72
79 // Run the message loop, observer should update members.
80 message_loop_.RunUntilIdle();
81 EXPECT_EQ(1U, GetNewLoginStateChangesCount()); 73 EXPECT_EQ(1U, GetNewLoginStateChangesCount());
82 EXPECT_EQ(LoginState::LOGGED_IN_USER_REGULAR, logged_in_user_type_); 74 EXPECT_EQ(LoginState::LOGGED_IN_USER_REGULAR, logged_in_user_type_);
83 } 75 }
84 76
85 TEST_F(LoginStateTest, TestSafeModeLoginState) { 77 TEST_F(LoginStateTest, TestSafeModeLoginState) {
86 EXPECT_FALSE(LoginState::Get()->IsUserLoggedIn()); 78 EXPECT_FALSE(LoginState::Get()->IsUserLoggedIn());
87 EXPECT_FALSE(LoginState::Get()->IsInSafeMode()); 79 EXPECT_FALSE(LoginState::Get()->IsInSafeMode());
88 EXPECT_EQ(LoginState::LOGGED_IN_USER_NONE, logged_in_user_type_); 80 EXPECT_EQ(LoginState::LOGGED_IN_USER_NONE, logged_in_user_type_);
89 EXPECT_EQ(LoginState::LOGGED_IN_USER_NONE, 81 EXPECT_EQ(LoginState::LOGGED_IN_USER_NONE,
90 LoginState::Get()->GetLoggedInUserType()); 82 LoginState::Get()->GetLoggedInUserType());
91 // Setting login state to SAFE MODE. 83 // Setting login state to SAFE MODE.
92 LoginState::Get()->SetLoggedInState(LoginState::LOGGED_IN_SAFE_MODE, 84 LoginState::Get()->SetLoggedInState(LoginState::LOGGED_IN_SAFE_MODE,
93 LoginState::LOGGED_IN_USER_NONE); 85 LoginState::LOGGED_IN_USER_NONE);
94 EXPECT_EQ(LoginState::LOGGED_IN_USER_NONE, 86 EXPECT_EQ(LoginState::LOGGED_IN_USER_NONE,
95 LoginState::Get()->GetLoggedInUserType()); 87 LoginState::Get()->GetLoggedInUserType());
96 EXPECT_FALSE(LoginState::Get()->IsUserLoggedIn()); 88 EXPECT_FALSE(LoginState::Get()->IsUserLoggedIn());
97 EXPECT_TRUE(LoginState::Get()->IsInSafeMode()); 89 EXPECT_TRUE(LoginState::Get()->IsInSafeMode());
98 90
99 // Run the message loop, observer should update members.
100 message_loop_.RunUntilIdle();
101 EXPECT_EQ(1U, GetNewLoginStateChangesCount()); 91 EXPECT_EQ(1U, GetNewLoginStateChangesCount());
102 EXPECT_EQ(LoginState::LOGGED_IN_USER_NONE, logged_in_user_type_); 92 EXPECT_EQ(LoginState::LOGGED_IN_USER_NONE, logged_in_user_type_);
103 93
104 // Setting login state to ACTIVE. 94 // Setting login state to ACTIVE.
105 LoginState::Get()->SetLoggedInState(LoginState::LOGGED_IN_ACTIVE, 95 LoginState::Get()->SetLoggedInState(LoginState::LOGGED_IN_ACTIVE,
106 LoginState::LOGGED_IN_USER_OWNER); 96 LoginState::LOGGED_IN_USER_OWNER);
107 EXPECT_EQ(LoginState::LOGGED_IN_USER_OWNER, 97 EXPECT_EQ(LoginState::LOGGED_IN_USER_OWNER,
108 LoginState::Get()->GetLoggedInUserType()); 98 LoginState::Get()->GetLoggedInUserType());
109 EXPECT_TRUE(LoginState::Get()->IsUserLoggedIn()); 99 EXPECT_TRUE(LoginState::Get()->IsUserLoggedIn());
110 EXPECT_FALSE(LoginState::Get()->IsInSafeMode()); 100 EXPECT_FALSE(LoginState::Get()->IsInSafeMode());
111 101
112 // Run the message loop, observer should update members.
113 message_loop_.RunUntilIdle();
114 EXPECT_EQ(1U, GetNewLoginStateChangesCount()); 102 EXPECT_EQ(1U, GetNewLoginStateChangesCount());
115 EXPECT_EQ(LoginState::LOGGED_IN_USER_OWNER, logged_in_user_type_); 103 EXPECT_EQ(LoginState::LOGGED_IN_USER_OWNER, logged_in_user_type_);
116 } 104 }
117 105
106 TEST_F(LoginStateTest, TestLoggedInStateChangedObserverOnUserTypeChange) {
107 LoginState::Get()->SetLoggedInState(LoginState::LOGGED_IN_ACTIVE,
108 LoginState::LOGGED_IN_USER_REGULAR);
109
110 EXPECT_EQ(1u, GetNewLoginStateChangesCount());
111 EXPECT_TRUE(LoginState::Get()->IsUserLoggedIn());
112 EXPECT_EQ(LoginState::LOGGED_IN_USER_REGULAR, logged_in_user_type_);
113 EXPECT_EQ(LoginState::LOGGED_IN_USER_REGULAR,
114 LoginState::Get()->GetLoggedInUserType());
115
116 // Change the user type, without changing the logged in state.
117 LoginState::Get()->SetLoggedInState(LoginState::LOGGED_IN_ACTIVE,
118 LoginState::LOGGED_IN_USER_OWNER);
119
120 EXPECT_EQ(1u, GetNewLoginStateChangesCount());
121 EXPECT_TRUE(LoginState::Get()->IsUserLoggedIn());
122 EXPECT_EQ(LoginState::LOGGED_IN_USER_OWNER, logged_in_user_type_);
123 EXPECT_EQ(LoginState::LOGGED_IN_USER_OWNER,
124 LoginState::Get()->GetLoggedInUserType());
125 }
126
118 } // namespace chromeos 127 } // namespace chromeos
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698