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

Unified Diff: chrome/browser/chromeos/policy/consumer_unenrollment_handler_unittest.cc

Issue 751703003: Implemented consumer management unenrollment. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@dcpm
Patch Set: Created 6 years, 1 month 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/chromeos/policy/consumer_unenrollment_handler_unittest.cc
diff --git a/chrome/browser/chromeos/policy/consumer_unenrollment_handler_unittest.cc b/chrome/browser/chromeos/policy/consumer_unenrollment_handler_unittest.cc
new file mode 100644
index 0000000000000000000000000000000000000000..694cb08eacdeb355f2b06cb0f4099e1187eaf1fd
--- /dev/null
+++ b/chrome/browser/chromeos/policy/consumer_unenrollment_handler_unittest.cc
@@ -0,0 +1,120 @@
+// Copyright 2014 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "chrome/browser/chromeos/policy/consumer_unenrollment_handler.h"
+
+#include "base/bind.h"
+#include "base/bind_helpers.h"
+#include "base/memory/scoped_ptr.h"
+#include "base/message_loop/message_loop_proxy.h"
+#include "chrome/browser/chromeos/policy/consumer_management_service.h"
+#include "chrome/browser/chromeos/policy/consumer_management_stage.h"
+#include "chrome/browser/chromeos/policy/device_cloud_policy_store_chromeos.h"
+#include "chrome/browser/chromeos/policy/enterprise_install_attributes.h"
+#include "chrome/browser/chromeos/policy/fake_consumer_management_service.h"
+#include "chrome/browser/chromeos/policy/fake_device_cloud_policy_manager.h"
+#include "chrome/browser/chromeos/settings/device_settings_test_helper.h"
+#include "chromeos/dbus/fake_cryptohome_client.h"
+#include "components/ownership/mock_owner_key_util.h"
+#include "policy/proto/device_management_backend.pb.h"
+#include "testing/gtest/include/gtest/gtest.h"
+
+namespace policy {
+
+class ConsumerUnenrollmentHandlerTest
+ : public chromeos::DeviceSettingsTestBase {
+ public:
+ ConsumerUnenrollmentHandlerTest()
+ : fake_service_(new FakeConsumerManagementService()),
+ fake_cryptohome_client_(new chromeos::FakeCryptohomeClient()),
+ install_attributes_(
+ new EnterpriseInstallAttributes(fake_cryptohome_client_)) {
+ // Set up FakeConsumerManagementService.
+ fake_service_->SetStatusAndStage(
+ ConsumerManagementService::STATUS_ENROLLED,
+ ConsumerManagementStage(ConsumerManagementStage::NONE));
+
+ }
+
+ void SetUp() override {
+ DeviceSettingsTestBase::SetUp();
+
+ // Set up the ownership, so that we can modify device settings.
+ owner_key_util_->SetPrivateKey(device_policy_.GetSigningKey());
+ InitOwner(device_policy_.policy_data().username(), true);
+ FlushDeviceSettings();
+
+ // Set up DeviceSettingsService.
+ device_settings_service_.SetManagementSettings(
+ enterprise_management::PolicyData::CONSUMER_MANAGED,
+ "fake_request_token",
+ "fake_device_id",
+ base::Bind(&ConsumerUnenrollmentHandlerTest::OnManagementSettingsSet,
+ base::Unretained(this)));
+ FlushDeviceSettings();
+
+ // Set up FakeDeviceCloudPolicyManager.
+ scoped_ptr<DeviceCloudPolicyStoreChromeOS> store_(
+ new DeviceCloudPolicyStoreChromeOS(
+ &device_settings_service_,
+ install_attributes_.get(),
+ base::MessageLoopProxy::current()));
bartfab (slow) 2014/11/28 13:25:18 Nit: Here and below: MessageLoopProxy is deprecate
davidyu 2014/12/01 17:05:22 Done.
+ fake_manager_.reset(new FakeDeviceCloudPolicyManager(
+ store_.Pass(),
+ base::MessageLoopProxy::current()));
+ }
+
+ void OnManagementSettingsSet() {
+ EXPECT_EQ(chromeos::DeviceSettingsService::STORE_SUCCESS,
bartfab (slow) 2014/11/28 13:25:18 Nit: #include "chrome/browser/chromeos/settings/de
davidyu 2014/12/01 17:05:22 Done.
+ device_settings_service_.status());
+ }
+
+ void RunUnenrollment() {
+ handler_.reset(new ConsumerUnenrollmentHandler(
+ &device_settings_service_,
+ fake_service_.get(),
+ fake_manager_.get()));
+ handler_->Start();
+ FlushDeviceSettings();
+ }
+
+ scoped_ptr<FakeConsumerManagementService> fake_service_;
+ chromeos::FakeCryptohomeClient* fake_cryptohome_client_;
+ scoped_ptr<EnterpriseInstallAttributes> install_attributes_;
+ scoped_ptr<FakeDeviceCloudPolicyManager> fake_manager_;
+
+ scoped_ptr<ConsumerUnenrollmentHandler> handler_;
+};
+
+TEST_F(ConsumerUnenrollmentHandlerTest, UnenrollmentSucceeds) {
+ EXPECT_EQ(ConsumerManagementStage::NONE, fake_service_->GetStage().value());
+
+ RunUnenrollment();
+
+ EXPECT_EQ(ConsumerManagementStage::UNENROLLMENT_SUCCESS,
+ fake_service_->GetStage().value());
+ EXPECT_EQ(enterprise_management::PolicyData::LOCAL_OWNER,
+ device_settings_service_.policy_data()->management_mode());
+ EXPECT_FALSE(device_settings_service_.policy_data()->has_request_token());
+ EXPECT_FALSE(device_settings_service_.policy_data()->has_device_id());
+}
+
+TEST_F(ConsumerUnenrollmentHandlerTest,
+ UnenrollmentFailsOnServerError) {
+ EXPECT_EQ(ConsumerManagementStage::NONE, fake_service_->GetStage().value());
+ fake_manager_->set_unregister_result(false);
+
+ RunUnenrollment();
+
+ EXPECT_EQ(ConsumerManagementStage::UNENROLLMENT_DM_SERVER_FAILED,
+ fake_service_->GetStage().value());
+ EXPECT_EQ(enterprise_management::PolicyData::CONSUMER_MANAGED,
+ device_settings_service_.policy_data()->management_mode());
+ EXPECT_EQ("fake_request_token",
+ device_settings_service_.policy_data()->request_token());
+ EXPECT_EQ("fake_device_id",
+ device_settings_service_.policy_data()->device_id());
+}
+
+} // namespace policy

Powered by Google App Engine
This is Rietveld 408576698