Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "chrome/browser/chromeos/policy/consumer_management_service.h" | 5 #include "chrome/browser/chromeos/policy/consumer_management_service.h" |
| 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/memory/scoped_ptr.h" | |
|
bartfab (slow)
2014/08/21 11:39:35
Actually, I missed it that the header already incl
davidyu
2014/08/22 05:14:13
Done.
| |
| 10 #include "base/prefs/pref_registry_simple.h" | 11 #include "base/prefs/pref_registry_simple.h" |
| 11 #include "base/prefs/pref_service.h" | 12 #include "base/prefs/pref_service.h" |
| 12 #include "base/prefs/testing_pref_service.h" | 13 #include "base/prefs/testing_pref_service.h" |
| 13 #include "base/run_loop.h" | 14 #include "base/run_loop.h" |
| 14 #include "chrome/browser/browser_process.h" | 15 #include "chrome/browser/browser_process.h" |
| 15 #include "chrome/browser/browser_process_platform_part.h" | 16 #include "chrome/browser/browser_process_platform_part.h" |
| 16 #include "chrome/browser/chrome_notification_types.h" | 17 #include "chrome/browser/chrome_notification_types.h" |
| 17 #include "chrome/browser/chromeos/login/users/mock_user_manager.h" | 18 #include "chrome/browser/chromeos/login/users/mock_user_manager.h" |
| 18 #include "chrome/browser/chromeos/login/users/scoped_user_manager_enabler.h" | 19 #include "chrome/browser/chromeos/login/users/scoped_user_manager_enabler.h" |
| 19 #include "chrome/browser/chromeos/policy/browser_policy_connector_chromeos.h" | 20 #include "chrome/browser/chromeos/policy/browser_policy_connector_chromeos.h" |
| 20 #include "chrome/browser/chromeos/policy/device_cloud_policy_initializer.h" | 21 #include "chrome/browser/chromeos/policy/device_cloud_policy_initializer.h" |
| 22 #include "chrome/browser/chromeos/policy/device_policy_builder.h" | |
| 21 #include "chrome/browser/chromeos/policy/enrollment_status_chromeos.h" | 23 #include "chrome/browser/chromeos/policy/enrollment_status_chromeos.h" |
| 22 #include "chrome/browser/chromeos/policy/fake_device_cloud_policy_initializer.h" | 24 #include "chrome/browser/chromeos/policy/fake_device_cloud_policy_initializer.h" |
| 25 #include "chrome/browser/chromeos/settings/device_settings_test_helper.h" | |
| 23 #include "chrome/browser/notifications/notification_ui_manager.h" | 26 #include "chrome/browser/notifications/notification_ui_manager.h" |
| 24 #include "chrome/browser/profiles/profile.h" | 27 #include "chrome/browser/profiles/profile.h" |
| 25 #include "chrome/browser/signin/fake_profile_oauth2_token_service.h" | 28 #include "chrome/browser/signin/fake_profile_oauth2_token_service.h" |
| 26 #include "chrome/browser/signin/fake_profile_oauth2_token_service_builder.h" | 29 #include "chrome/browser/signin/fake_profile_oauth2_token_service_builder.h" |
| 27 #include "chrome/browser/signin/profile_oauth2_token_service_factory.h" | 30 #include "chrome/browser/signin/profile_oauth2_token_service_factory.h" |
| 28 #include "chrome/browser/signin/signin_manager_factory.h" | 31 #include "chrome/browser/signin/signin_manager_factory.h" |
| 29 #include "chrome/common/pref_names.h" | 32 #include "chrome/common/pref_names.h" |
| 30 #include "chrome/test/base/browser_with_test_window_test.h" | 33 #include "chrome/test/base/browser_with_test_window_test.h" |
| 34 #include "chrome/test/base/scoped_testing_local_state.h" | |
| 31 #include "chrome/test/base/testing_browser_process.h" | 35 #include "chrome/test/base/testing_browser_process.h" |
| 32 #include "chrome/test/base/testing_profile.h" | 36 #include "chrome/test/base/testing_profile.h" |
| 33 #include "chrome/test/base/testing_profile_manager.h" | 37 #include "chrome/test/base/testing_profile_manager.h" |
| 34 #include "chromeos/dbus/cryptohome/rpc.pb.h" | 38 #include "chromeos/dbus/cryptohome/rpc.pb.h" |
| 35 #include "chromeos/dbus/cryptohome_client.h" | 39 #include "chromeos/dbus/cryptohome_client.h" |
| 36 #include "chromeos/dbus/mock_cryptohome_client.h" | 40 #include "chromeos/dbus/mock_cryptohome_client.h" |
| 37 #include "components/signin/core/browser/profile_oauth2_token_service.h" | 41 #include "components/signin/core/browser/profile_oauth2_token_service.h" |
| 38 #include "components/signin/core/browser/signin_manager_base.h" | 42 #include "components/signin/core/browser/signin_manager_base.h" |
| 39 #include "content/public/browser/notification_details.h" | 43 #include "content/public/browser/notification_details.h" |
| 40 #include "content/public/browser/notification_source.h" | 44 #include "content/public/browser/notification_source.h" |
| 41 #include "google_apis/gaia/google_service_auth_error.h" | 45 #include "google_apis/gaia/google_service_auth_error.h" |
| 46 #include "policy/proto/device_management_backend.pb.h" | |
| 42 #include "testing/gmock/include/gmock/gmock.h" | 47 #include "testing/gmock/include/gmock/gmock.h" |
| 43 #include "testing/gtest/include/gtest/gtest.h" | 48 #include "testing/gtest/include/gtest/gtest.h" |
| 44 | 49 |
| 45 using testing::Invoke; | 50 using testing::Invoke; |
| 46 using testing::NiceMock; | 51 using testing::NiceMock; |
| 47 using testing::Return; | 52 using testing::Return; |
| 48 using testing::_; | 53 using testing::_; |
| 49 | 54 |
| 55 namespace em = enterprise_management; | |
| 56 | |
| 50 namespace { | 57 namespace { |
| 51 const char* kAttributeOwnerId = "consumer_management.owner_id"; | 58 const char* kAttributeOwnerId = "consumer_management.owner_id"; |
| 52 const char* kTestOwner = "test@chromium.org.test"; | 59 const char* kTestOwner = "test@chromium.org.test"; |
| 53 } | 60 } |
| 54 | 61 |
| 55 namespace policy { | 62 namespace policy { |
| 56 | 63 |
| 57 class ConsumerManagementServiceTest : public BrowserWithTestWindowTest { | 64 class ConsumerManagementServiceTest : public BrowserWithTestWindowTest { |
| 58 public: | 65 public: |
| 59 ConsumerManagementServiceTest() | 66 ConsumerManagementServiceTest() |
| (...skipping 12 matching lines...) Expand all Loading... | |
| 72 MockFlushAndSignBootAttributes)); | 79 MockFlushAndSignBootAttributes)); |
| 73 } | 80 } |
| 74 | 81 |
| 75 virtual void SetUp() OVERRIDE { | 82 virtual void SetUp() OVERRIDE { |
| 76 BrowserWithTestWindowTest::SetUp(); | 83 BrowserWithTestWindowTest::SetUp(); |
| 77 | 84 |
| 78 testing_profile_manager_.reset(new TestingProfileManager( | 85 testing_profile_manager_.reset(new TestingProfileManager( |
| 79 TestingBrowserProcess::GetGlobal())); | 86 TestingBrowserProcess::GetGlobal())); |
| 80 ASSERT_TRUE(testing_profile_manager_->SetUp()); | 87 ASSERT_TRUE(testing_profile_manager_->SetUp()); |
| 81 | 88 |
| 82 service_.reset(new ConsumerManagementService(&mock_cryptohome_client_)); | 89 service_.reset(new ConsumerManagementService(&mock_cryptohome_client_, |
| 90 NULL)); | |
| 83 } | 91 } |
| 84 | 92 |
| 85 virtual void TearDown() OVERRIDE { | 93 virtual void TearDown() OVERRIDE { |
| 86 testing_profile_manager_.reset(); | 94 testing_profile_manager_.reset(); |
| 87 | 95 |
| 88 service_.reset(); | 96 service_.reset(); |
| 89 | 97 |
| 90 BrowserWithTestWindowTest::TearDown(); | 98 BrowserWithTestWindowTest::TearDown(); |
| 91 } | 99 } |
| 92 | 100 |
| 93 ConsumerManagementService::ConsumerEnrollmentState GetEnrollmentState() { | 101 ConsumerManagementService::EnrollmentStage GetEnrollmentStage() { |
| 94 return static_cast<ConsumerManagementService::ConsumerEnrollmentState>( | 102 return static_cast<ConsumerManagementService::EnrollmentStage>( |
| 95 g_browser_process->local_state()->GetInteger( | 103 g_browser_process->local_state()->GetInteger( |
| 96 prefs::kConsumerManagementEnrollmentState)); | 104 prefs::kConsumerManagementEnrollmentStage)); |
| 97 } | 105 } |
| 98 | 106 |
| 99 void SetEnrollmentState( | 107 void SetEnrollmentStage(ConsumerManagementService::EnrollmentStage stage) { |
| 100 ConsumerManagementService::ConsumerEnrollmentState state) { | |
| 101 g_browser_process->local_state()->SetInteger( | 108 g_browser_process->local_state()->SetInteger( |
| 102 prefs::kConsumerManagementEnrollmentState, state); | 109 prefs::kConsumerManagementEnrollmentStage, stage); |
| 103 } | 110 } |
| 104 | 111 |
| 105 void MockGetBootAttribute( | 112 void MockGetBootAttribute( |
| 106 const cryptohome::GetBootAttributeRequest& request, | 113 const cryptohome::GetBootAttributeRequest& request, |
| 107 const chromeos::CryptohomeClient::ProtobufMethodCallback& callback) { | 114 const chromeos::CryptohomeClient::ProtobufMethodCallback& callback) { |
| 108 get_boot_attribute_request_ = request; | 115 get_boot_attribute_request_ = request; |
| 109 callback.Run(cryptohome_status_, cryptohome_result_, cryptohome_reply_); | 116 callback.Run(cryptohome_status_, cryptohome_result_, cryptohome_reply_); |
| 110 } | 117 } |
| 111 | 118 |
| 112 void MockSetBootAttribute( | 119 void MockSetBootAttribute( |
| (...skipping 10 matching lines...) Expand all Loading... | |
| 123 } | 130 } |
| 124 | 131 |
| 125 void OnGetOwnerDone(const std::string& owner) { | 132 void OnGetOwnerDone(const std::string& owner) { |
| 126 owner_ = owner; | 133 owner_ = owner; |
| 127 } | 134 } |
| 128 | 135 |
| 129 void OnSetOwnerDone(bool status) { | 136 void OnSetOwnerDone(bool status) { |
| 130 set_owner_status_ = status; | 137 set_owner_status_ = status; |
| 131 } | 138 } |
| 132 | 139 |
| 140 // Variables for building the service. | |
| 133 NiceMock<chromeos::MockCryptohomeClient> mock_cryptohome_client_; | 141 NiceMock<chromeos::MockCryptohomeClient> mock_cryptohome_client_; |
| 134 scoped_ptr<ConsumerManagementService> service_; | 142 scoped_ptr<ConsumerManagementService> service_; |
| 135 | 143 |
| 136 scoped_ptr<TestingProfileManager> testing_profile_manager_; | 144 scoped_ptr<TestingProfileManager> testing_profile_manager_; |
| 145 | |
| 146 // Variables for setting the return value or catching the arguments of mock | |
| 147 // functions. | |
| 137 chromeos::DBusMethodCallStatus cryptohome_status_; | 148 chromeos::DBusMethodCallStatus cryptohome_status_; |
| 138 bool cryptohome_result_; | 149 bool cryptohome_result_; |
| 139 cryptohome::BaseReply cryptohome_reply_; | 150 cryptohome::BaseReply cryptohome_reply_; |
| 140 cryptohome::GetBootAttributeRequest get_boot_attribute_request_; | 151 cryptohome::GetBootAttributeRequest get_boot_attribute_request_; |
| 141 cryptohome::SetBootAttributeRequest set_boot_attribute_request_; | 152 cryptohome::SetBootAttributeRequest set_boot_attribute_request_; |
| 142 | |
| 143 std::string owner_; | 153 std::string owner_; |
| 144 bool set_owner_status_; | 154 bool set_owner_status_; |
| 145 }; | 155 }; |
| 146 | 156 |
| 147 TEST_F(ConsumerManagementServiceTest, CanGetEnrollmentState) { | 157 TEST_F(ConsumerManagementServiceTest, CanGetEnrollmentStage) { |
| 148 EXPECT_EQ(ConsumerManagementService::ENROLLMENT_NONE, | 158 EXPECT_EQ(ConsumerManagementService::ENROLLMENT_STAGE_NONE, |
| 149 service_->GetEnrollmentState()); | 159 service_->GetEnrollmentStage()); |
| 150 | 160 |
| 151 SetEnrollmentState(ConsumerManagementService::ENROLLMENT_REQUESTED); | 161 SetEnrollmentStage(ConsumerManagementService::ENROLLMENT_STAGE_REQUESTED); |
| 152 | 162 |
| 153 EXPECT_EQ(ConsumerManagementService::ENROLLMENT_REQUESTED, | 163 EXPECT_EQ(ConsumerManagementService::ENROLLMENT_STAGE_REQUESTED, |
| 154 service_->GetEnrollmentState()); | 164 service_->GetEnrollmentStage()); |
| 155 } | 165 } |
| 156 | 166 |
| 157 TEST_F(ConsumerManagementServiceTest, CanSetEnrollmentState) { | 167 TEST_F(ConsumerManagementServiceTest, CanSetEnrollmentStage) { |
| 158 EXPECT_EQ(ConsumerManagementService::ENROLLMENT_NONE, GetEnrollmentState()); | 168 EXPECT_EQ(ConsumerManagementService::ENROLLMENT_STAGE_NONE, |
| 169 GetEnrollmentStage()); | |
| 159 | 170 |
| 160 service_->SetEnrollmentState(ConsumerManagementService::ENROLLMENT_REQUESTED); | 171 service_->SetEnrollmentStage( |
| 172 ConsumerManagementService::ENROLLMENT_STAGE_REQUESTED); | |
| 161 | 173 |
| 162 EXPECT_EQ(ConsumerManagementService::ENROLLMENT_REQUESTED, | 174 EXPECT_EQ(ConsumerManagementService::ENROLLMENT_STAGE_REQUESTED, |
| 163 GetEnrollmentState()); | 175 GetEnrollmentStage()); |
| 164 } | 176 } |
| 165 | 177 |
| 166 TEST_F(ConsumerManagementServiceTest, CanGetOwner) { | 178 TEST_F(ConsumerManagementServiceTest, CanGetOwner) { |
| 167 cryptohome_status_ = chromeos::DBUS_METHOD_CALL_SUCCESS; | 179 cryptohome_status_ = chromeos::DBUS_METHOD_CALL_SUCCESS; |
| 168 cryptohome_result_ = true; | 180 cryptohome_result_ = true; |
| 169 cryptohome_reply_.MutableExtension(cryptohome::GetBootAttributeReply::reply)-> | 181 cryptohome_reply_.MutableExtension(cryptohome::GetBootAttributeReply::reply)-> |
| 170 set_value(kTestOwner); | 182 set_value(kTestOwner); |
| 171 | 183 |
| 172 service_->GetOwner(base::Bind(&ConsumerManagementServiceTest::OnGetOwnerDone, | 184 service_->GetOwner(base::Bind(&ConsumerManagementServiceTest::OnGetOwnerDone, |
| 173 base::Unretained(this))); | 185 base::Unretained(this))); |
| (...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 217 public: | 229 public: |
| 218 ConsumerManagementServiceEnrollmentTest() | 230 ConsumerManagementServiceEnrollmentTest() |
| 219 : mock_user_manager_(new NiceMock<chromeos::MockUserManager>()), | 231 : mock_user_manager_(new NiceMock<chromeos::MockUserManager>()), |
| 220 scoped_user_manager_enabler_(mock_user_manager_), | 232 scoped_user_manager_enabler_(mock_user_manager_), |
| 221 fake_initializer_(new FakeDeviceCloudPolicyInitializer()), | 233 fake_initializer_(new FakeDeviceCloudPolicyInitializer()), |
| 222 enrollment_status_(EnrollmentStatus::ForStatus( | 234 enrollment_status_(EnrollmentStatus::ForStatus( |
| 223 EnrollmentStatus::STATUS_SUCCESS)) { | 235 EnrollmentStatus::STATUS_SUCCESS)) { |
| 224 // Set up MockUserManager. The first user will be the owner. | 236 // Set up MockUserManager. The first user will be the owner. |
| 225 mock_user_manager_->AddUser(kTestOwner); | 237 mock_user_manager_->AddUser(kTestOwner); |
| 226 | 238 |
| 227 // Return false for IsCurrentUserOwner() so that the enrollment state is not | 239 // Return false for IsCurrentUserOwner() so that the enrollment stage is not |
| 228 // reset. | 240 // reset. |
| 229 ON_CALL(*mock_user_manager_, IsCurrentUserOwner()) | 241 ON_CALL(*mock_user_manager_, IsCurrentUserOwner()) |
| 230 .WillByDefault(Return(false)); | 242 .WillByDefault(Return(false)); |
| 231 | 243 |
| 232 // Inject FakeDeviceCloudPolicyInitializer. | 244 // Inject FakeDeviceCloudPolicyInitializer. |
| 233 BrowserPolicyConnectorChromeOS* connector = | 245 BrowserPolicyConnectorChromeOS* connector = |
| 234 g_browser_process->platform_part()->browser_policy_connector_chromeos(); | 246 g_browser_process->platform_part()->browser_policy_connector_chromeos(); |
| 235 connector->SetDeviceCloudPolicyInitializerForTesting( | 247 connector->SetDeviceCloudPolicyInitializerForTesting( |
| 236 scoped_ptr<DeviceCloudPolicyInitializer>(fake_initializer_)); | 248 scoped_ptr<DeviceCloudPolicyInitializer>(fake_initializer_)); |
| 237 } | 249 } |
| 238 | 250 |
| 239 virtual void SetUp() OVERRIDE { | 251 virtual void SetUp() OVERRIDE { |
| 240 ConsumerManagementServiceTest::SetUp(); | 252 ConsumerManagementServiceTest::SetUp(); |
| 241 | 253 |
| 242 // Set up the testing profile. | 254 // Set up the testing profile. |
| 243 profile()->set_profile_name(kTestOwner); | 255 profile()->set_profile_name(kTestOwner); |
| 244 | 256 |
| 245 // Set up FakeProfileOAuth2TokenService and issue a fake refresh token. | 257 // Set up FakeProfileOAuth2TokenService and issue a fake refresh token. |
| 246 ProfileOAuth2TokenServiceFactory::GetInstance()->SetTestingFactory( | 258 ProfileOAuth2TokenServiceFactory::GetInstance()->SetTestingFactory( |
| 247 profile(), &BuildAutoIssuingFakeProfileOAuth2TokenService); | 259 profile(), &BuildAutoIssuingFakeProfileOAuth2TokenService); |
| 248 GetFakeProfileOAuth2TokenService()-> | 260 GetFakeProfileOAuth2TokenService()-> |
| 249 IssueRefreshTokenForUser(kTestOwner, "fake_token"); | 261 IssueRefreshTokenForUser(kTestOwner, "fake_token"); |
| 250 | 262 |
| 251 // Set up the authenticated user name and ID. | 263 // Set up the authenticated user name and ID. |
| 252 SigninManagerFactory::GetForProfile(profile())-> | 264 SigninManagerFactory::GetForProfile(profile())-> |
| 253 SetAuthenticatedUsername(kTestOwner); | 265 SetAuthenticatedUsername(kTestOwner); |
| 254 | 266 |
| 255 // The service should continue the enrollment process if the state is | 267 // The service should continue the enrollment process if the stage is |
| 256 // ENROLLMENT_OWNER_STORED. | 268 // ENROLLMENT_STAGE_OWNER_STORED. |
| 257 SetEnrollmentState(ConsumerManagementService::ENROLLMENT_OWNER_STORED); | 269 SetEnrollmentStage( |
| 270 ConsumerManagementService::ENROLLMENT_STAGE_OWNER_STORED); | |
| 258 } | 271 } |
| 259 | 272 |
| 260 virtual void TearDown() OVERRIDE { | 273 virtual void TearDown() OVERRIDE { |
| 261 g_browser_process->notification_ui_manager()->CancelAll(); | 274 g_browser_process->notification_ui_manager()->CancelAll(); |
| 262 | 275 |
| 263 ConsumerManagementServiceTest::TearDown(); | 276 ConsumerManagementServiceTest::TearDown(); |
| 264 } | 277 } |
| 265 | 278 |
| 266 FakeProfileOAuth2TokenService* GetFakeProfileOAuth2TokenService() { | 279 FakeProfileOAuth2TokenService* GetFakeProfileOAuth2TokenService() { |
| 267 return static_cast<FakeProfileOAuth2TokenService*>( | 280 return static_cast<FakeProfileOAuth2TokenService*>( |
| (...skipping 18 matching lines...) Expand all Loading... | |
| 286 FakeDeviceCloudPolicyInitializer* fake_initializer_; | 299 FakeDeviceCloudPolicyInitializer* fake_initializer_; |
| 287 EnrollmentStatus enrollment_status_; | 300 EnrollmentStatus enrollment_status_; |
| 288 }; | 301 }; |
| 289 | 302 |
| 290 TEST_F(ConsumerManagementServiceEnrollmentTest, EnrollsSuccessfully) { | 303 TEST_F(ConsumerManagementServiceEnrollmentTest, EnrollsSuccessfully) { |
| 291 EXPECT_FALSE(fake_initializer_->was_start_enrollment_called()); | 304 EXPECT_FALSE(fake_initializer_->was_start_enrollment_called()); |
| 292 | 305 |
| 293 RunEnrollmentTest(); | 306 RunEnrollmentTest(); |
| 294 | 307 |
| 295 EXPECT_TRUE(fake_initializer_->was_start_enrollment_called()); | 308 EXPECT_TRUE(fake_initializer_->was_start_enrollment_called()); |
| 296 EXPECT_EQ(ConsumerManagementService::ENROLLMENT_SUCCESS, | 309 EXPECT_EQ(ConsumerManagementService::ENROLLMENT_STAGE_SUCCESS, |
| 297 GetEnrollmentState()); | 310 GetEnrollmentStage()); |
| 298 EXPECT_FALSE(HasEnrollmentNotification()); | 311 EXPECT_FALSE(HasEnrollmentNotification()); |
| 299 } | 312 } |
| 300 | 313 |
| 301 TEST_F(ConsumerManagementServiceEnrollmentTest, | 314 TEST_F(ConsumerManagementServiceEnrollmentTest, |
| 302 ShowsDesktopNotificationAndResetsEnrollmentStateIfCurrentUserIsOwner) { | 315 ShowsDesktopNotificationAndResetsEnrollmentStageIfCurrentUserIsOwner) { |
| 303 EXPECT_EQ(ConsumerManagementService::ENROLLMENT_OWNER_STORED, | 316 EXPECT_EQ(ConsumerManagementService::ENROLLMENT_STAGE_OWNER_STORED, |
| 304 GetEnrollmentState()); | 317 GetEnrollmentStage()); |
| 305 EXPECT_FALSE(HasEnrollmentNotification()); | 318 EXPECT_FALSE(HasEnrollmentNotification()); |
| 306 EXPECT_CALL(*mock_user_manager_, IsCurrentUserOwner()) | 319 EXPECT_CALL(*mock_user_manager_, IsCurrentUserOwner()) |
| 307 .WillOnce(Return(true)); | 320 .WillOnce(Return(true)); |
| 308 | 321 |
| 309 RunEnrollmentTest(); | 322 RunEnrollmentTest(); |
| 310 | 323 |
| 311 EXPECT_EQ(ConsumerManagementService::ENROLLMENT_NONE, GetEnrollmentState()); | 324 EXPECT_EQ(ConsumerManagementService::ENROLLMENT_STAGE_NONE, |
| 325 GetEnrollmentStage()); | |
| 312 EXPECT_TRUE(HasEnrollmentNotification()); | 326 EXPECT_TRUE(HasEnrollmentNotification()); |
| 313 } | 327 } |
| 314 | 328 |
| 315 TEST_F(ConsumerManagementServiceEnrollmentTest, FailsToGetAccessToken) { | 329 TEST_F(ConsumerManagementServiceEnrollmentTest, FailsToGetAccessToken) { |
| 316 // Disable auto-posting so that RunEnrollmentTest() should stop and wait for | 330 // Disable auto-posting so that RunEnrollmentTest() should stop and wait for |
| 317 // the access token to be available. | 331 // the access token to be available. |
| 318 GetFakeProfileOAuth2TokenService()-> | 332 GetFakeProfileOAuth2TokenService()-> |
| 319 set_auto_post_fetch_response_on_message_loop(false); | 333 set_auto_post_fetch_response_on_message_loop(false); |
| 320 | 334 |
| 321 RunEnrollmentTest(); | 335 RunEnrollmentTest(); |
| 322 | 336 |
| 323 // The service should have a pending token request. | 337 // The service should have a pending token request. |
| 324 OAuth2TokenService::Request* token_request = | 338 OAuth2TokenService::Request* token_request = |
| 325 service_->GetTokenRequestForTesting(); | 339 service_->GetTokenRequestForTesting(); |
| 326 EXPECT_TRUE(token_request); | 340 EXPECT_TRUE(token_request); |
| 327 | 341 |
| 328 // Tell the service that the access token is not available because of some | 342 // Tell the service that the access token is not available because of some |
| 329 // backend issue. | 343 // backend issue. |
| 330 service_->OnGetTokenFailure( | 344 service_->OnGetTokenFailure( |
| 331 token_request, | 345 token_request, |
| 332 GoogleServiceAuthError(GoogleServiceAuthError::SERVICE_ERROR)); | 346 GoogleServiceAuthError(GoogleServiceAuthError::SERVICE_ERROR)); |
| 333 | 347 |
| 334 EXPECT_FALSE(fake_initializer_->was_start_enrollment_called()); | 348 EXPECT_FALSE(fake_initializer_->was_start_enrollment_called()); |
| 335 EXPECT_EQ(ConsumerManagementService::ENROLLMENT_GET_TOKEN_FAILED, | 349 EXPECT_EQ(ConsumerManagementService::ENROLLMENT_STAGE_GET_TOKEN_FAILED, |
| 336 GetEnrollmentState()); | 350 GetEnrollmentStage()); |
| 337 } | 351 } |
| 338 | 352 |
| 339 TEST_F(ConsumerManagementServiceEnrollmentTest, FailsToRegister) { | 353 TEST_F(ConsumerManagementServiceEnrollmentTest, FailsToRegister) { |
| 340 EXPECT_FALSE(fake_initializer_->was_start_enrollment_called()); | 354 EXPECT_FALSE(fake_initializer_->was_start_enrollment_called()); |
| 341 fake_initializer_->set_enrollment_status(EnrollmentStatus::ForStatus( | 355 fake_initializer_->set_enrollment_status(EnrollmentStatus::ForStatus( |
| 342 EnrollmentStatus::STATUS_REGISTRATION_FAILED)); | 356 EnrollmentStatus::STATUS_REGISTRATION_FAILED)); |
| 343 | 357 |
| 344 RunEnrollmentTest(); | 358 RunEnrollmentTest(); |
| 345 | 359 |
| 346 EXPECT_TRUE(fake_initializer_->was_start_enrollment_called()); | 360 EXPECT_TRUE(fake_initializer_->was_start_enrollment_called()); |
| 347 EXPECT_EQ(ConsumerManagementService::ENROLLMENT_DM_SERVER_FAILED, | 361 EXPECT_EQ(ConsumerManagementService::ENROLLMENT_STAGE_DM_SERVER_FAILED, |
| 348 GetEnrollmentState()); | 362 GetEnrollmentStage()); |
| 349 } | 363 } |
| 350 | 364 |
| 351 TEST_F(ConsumerManagementServiceEnrollmentTest, | 365 TEST_F(ConsumerManagementServiceEnrollmentTest, |
| 352 ShowsDesktopNotificationOnlyIfEnrollmentIsAlreadyCompleted) { | 366 ShowsDesktopNotificationOnlyIfEnrollmentIsAlreadyCompleted) { |
| 353 SetEnrollmentState(ConsumerManagementService::ENROLLMENT_CANCELED); | 367 SetEnrollmentStage(ConsumerManagementService::ENROLLMENT_STAGE_CANCELED); |
| 354 EXPECT_FALSE(HasEnrollmentNotification()); | 368 EXPECT_FALSE(HasEnrollmentNotification()); |
| 355 | 369 |
| 356 RunEnrollmentTest(); | 370 RunEnrollmentTest(); |
| 357 | 371 |
| 358 EXPECT_FALSE(fake_initializer_->was_start_enrollment_called()); | 372 EXPECT_FALSE(fake_initializer_->was_start_enrollment_called()); |
| 359 EXPECT_EQ(ConsumerManagementService::ENROLLMENT_NONE, GetEnrollmentState()); | 373 EXPECT_EQ(ConsumerManagementService::ENROLLMENT_STAGE_NONE, |
| 374 GetEnrollmentStage()); | |
| 360 EXPECT_TRUE(HasEnrollmentNotification()); | 375 EXPECT_TRUE(HasEnrollmentNotification()); |
| 361 } | 376 } |
| 362 | 377 |
| 378 class ConsumerManagementServiceStatusTest | |
| 379 : public chromeos::DeviceSettingsTestBase { | |
| 380 public: | |
| 381 ConsumerManagementServiceStatusTest() | |
| 382 : testing_local_state_(TestingBrowserProcess::GetGlobal()), | |
| 383 service_(NULL, &device_settings_service_) { | |
| 384 } | |
| 385 | |
| 386 void SetEnrollmentStage(ConsumerManagementService::EnrollmentStage stage) { | |
| 387 testing_local_state_.Get()->SetInteger( | |
| 388 prefs::kConsumerManagementEnrollmentStage, stage); | |
| 389 } | |
| 390 | |
| 391 void SetManagementMode(em::PolicyData::ManagementMode mode) { | |
| 392 device_policy_.policy_data().set_management_mode(mode); | |
| 393 device_policy_.Build(); | |
| 394 device_settings_test_helper_.set_policy_blob(device_policy_.GetBlob()); | |
| 395 ReloadDeviceSettings(); | |
| 396 } | |
| 397 | |
| 398 ScopedTestingLocalState testing_local_state_; | |
| 399 ConsumerManagementService service_; | |
| 400 }; | |
| 401 | |
| 402 TEST_F(ConsumerManagementServiceStatusTest, GetStatusWorks) { | |
| 403 EXPECT_EQ(ConsumerManagementService::STATUS_UNKNOWN, service_.GetStatus()); | |
| 404 | |
| 405 SetManagementMode(em::PolicyData::NOT_MANAGED); | |
| 406 SetEnrollmentStage(ConsumerManagementService::ENROLLMENT_STAGE_NONE); | |
| 407 | |
| 408 EXPECT_EQ(ConsumerManagementService::STATUS_UNENROLLED, service_.GetStatus()); | |
| 409 | |
| 410 SetEnrollmentStage(ConsumerManagementService::ENROLLMENT_STAGE_REQUESTED); | |
| 411 | |
| 412 EXPECT_EQ(ConsumerManagementService::STATUS_ENROLLING, service_.GetStatus()); | |
| 413 | |
| 414 SetManagementMode(em::PolicyData::CONSUMER_MANAGED); | |
| 415 SetEnrollmentStage(ConsumerManagementService::ENROLLMENT_STAGE_SUCCESS); | |
| 416 | |
| 417 EXPECT_EQ(ConsumerManagementService::STATUS_ENROLLED, service_.GetStatus()); | |
| 418 | |
| 419 // TODO(davidyu): Test for STATUS_UNENROLLING when it is implemented. | |
| 420 // http://crbug.com/353050. | |
| 421 } | |
| 422 | |
| 423 TEST_F(ConsumerManagementServiceStatusTest, GetStatusStringWorks) { | |
| 424 EXPECT_EQ("STATUS_UNKNOWN", | |
| 425 ConsumerManagementService::GetStatusString( | |
| 426 ConsumerManagementService::STATUS_UNKNOWN)); | |
| 427 | |
| 428 EXPECT_EQ("STATUS_UNENROLLED", | |
| 429 ConsumerManagementService::GetStatusString( | |
| 430 ConsumerManagementService::STATUS_UNENROLLED)); | |
| 431 } | |
| 432 | |
| 363 } // namespace policy | 433 } // namespace policy |
| OLD | NEW |