Chromium Code Reviews| Index: chrome/browser/chromeos/system/device_disabling_manager_unittest.cc |
| diff --git a/chrome/browser/chromeos/system/device_disabling_manager_unittest.cc b/chrome/browser/chromeos/system/device_disabling_manager_unittest.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..fbdedb15f213dd41cbf86bb8dae3dba97d0131ec |
| --- /dev/null |
| +++ b/chrome/browser/chromeos/system/device_disabling_manager_unittest.cc |
| @@ -0,0 +1,179 @@ |
| +// 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/system/device_disabling_manager.h" |
| + |
| +#include "base/bind.h" |
| +#include "base/bind_helpers.h" |
| +#include "base/command_line.h" |
| +#include "base/memory/scoped_ptr.h" |
| +#include "base/prefs/scoped_user_pref_update.h" |
| +#include "base/prefs/testing_pref_service.h" |
| +#include "base/run_loop.h" |
| +#include "chrome/browser/browser_process_platform_part.h" |
| +#include "chrome/browser/chromeos/policy/browser_policy_connector_chromeos.h" |
| +#include "chrome/browser/chromeos/policy/device_cloud_policy_manager_chromeos.h" |
| +#include "chrome/browser/chromeos/policy/server_backed_device_state.h" |
| +#include "chrome/browser/chromeos/policy/stub_enterprise_install_attributes.h" |
| +#include "chrome/common/pref_names.h" |
| +#include "chrome/test/base/testing_browser_process.h" |
| +#include "chromeos/chromeos_switches.h" |
| +#include "components/policy/core/common/cloud/cloud_policy_constants.h" |
| +#include "testing/gtest/include/gtest/gtest.h" |
| + |
| +namespace chromeos { |
| +namespace system { |
| + |
| +namespace { |
| + |
| +const char kDisabledMessage[] = "Device disabled."; |
| + |
| +} |
| + |
| +class DeviceDisablingManagerTest : public testing::Test { |
| + public: |
| + DeviceDisablingManagerTest(); |
| + ~DeviceDisablingManagerTest(); |
|
achuithb
2014/11/05 19:59:55
virtual or override?
bartfab (slow)
2014/11/06 16:14:38
Actually, the explicit distructor is completely un
|
| + |
| + // testing::Test: |
| + void SetUp() override; |
| + void TearDown() override; |
| + |
| + bool IsDeviceDisabled() const; |
| + const std::string& GetDisabledMessage() const; |
| + |
| + void CheckWhetherDeviceDisabledDuringOOBE(); |
| + |
| + void SetDeviceDisabled(bool disabled); |
| + void SetDeviceMode(policy::DeviceMode device_mode); |
| + |
| + private: |
| + void OnDeviceDisabledChecked(bool device_disabled); |
| + |
| + policy::ScopedStubEnterpriseInstallAttributes install_attributes_; |
| + TestingPrefServiceSimple local_state_; |
| + |
| + scoped_ptr<DeviceDisablingManager> device_disabling_manager_; |
| + |
| + base::RunLoop run_loop_; |
| + bool device_disabled_; |
| + |
| + DISALLOW_COPY_AND_ASSIGN(DeviceDisablingManagerTest); |
| +}; |
| + |
| +DeviceDisablingManagerTest::DeviceDisablingManagerTest() |
| + : install_attributes_("", "", "", policy::DEVICE_MODE_NOT_SET), |
| + device_disabled_(false) { |
| +} |
| + |
| +DeviceDisablingManagerTest::~DeviceDisablingManagerTest() { |
| +} |
| + |
| +void DeviceDisablingManagerTest::SetUp() { |
| + TestingBrowserProcess::GetGlobal()->SetLocalState(&local_state_); |
| + policy::DeviceCloudPolicyManagerChromeOS::RegisterPrefs( |
| + local_state_.registry()); |
| + |
| + device_disabling_manager_.reset(new DeviceDisablingManager( |
| + TestingBrowserProcess::GetGlobal()->platform_part()-> |
| + browser_policy_connector_chromeos())); |
| +} |
| + |
| +void DeviceDisablingManagerTest::TearDown() { |
| + TestingBrowserProcess::GetGlobal()->SetLocalState(nullptr); |
| +} |
| + |
| +bool DeviceDisablingManagerTest::IsDeviceDisabled() const { |
| + return device_disabled_; |
| +} |
| + |
| +const std::string& DeviceDisablingManagerTest::GetDisabledMessage() const { |
| + return device_disabling_manager_->GetDisabledMessage(); |
| + |
| +} |
| + |
| +void DeviceDisablingManagerTest::CheckWhetherDeviceDisabledDuringOOBE() { |
| + device_disabling_manager_->CheckWhetherDeviceDisabledDuringOOBE( |
| + base::Bind(&DeviceDisablingManagerTest::OnDeviceDisabledChecked, |
| + base::Unretained(this))); |
| + run_loop_.Run(); |
| +} |
| + |
| +void DeviceDisablingManagerTest::SetDeviceDisabled(bool disabled) { |
| + DictionaryPrefUpdate dict(&local_state_, prefs::kServerBackedDeviceState); |
| + if (disabled) { |
| + dict->SetString(policy::kDeviceStateRestoreMode, |
| + policy::kDeviceStateRestoreModeDisabled); |
| + } else { |
| + dict->Remove(policy::kDeviceStateRestoreMode, nullptr); |
| + } |
| + dict->SetString(policy::kDeviceStateDisabledMessage, kDisabledMessage); |
| +} |
| + |
| +void DeviceDisablingManagerTest::SetDeviceMode(policy::DeviceMode device_mode) { |
| + reinterpret_cast<policy::StubEnterpriseInstallAttributes*>( |
| + TestingBrowserProcess::GetGlobal()->platform_part()-> |
| + browser_policy_connector_chromeos()->GetInstallAttributes())-> |
| + SetMode(device_mode); |
| +} |
| + |
| +void DeviceDisablingManagerTest::OnDeviceDisabledChecked(bool device_disabled) { |
| + device_disabled_ = device_disabled; |
| + run_loop_.Quit(); |
| +} |
| + |
| +// Verifies that the device is not considered disabled during OOBE by default. |
| +TEST_F(DeviceDisablingManagerTest, NotDisabledByDefault) { |
| + CheckWhetherDeviceDisabledDuringOOBE(); |
| + EXPECT_FALSE(IsDeviceDisabled()); |
| +} |
| + |
| +// Verifies that the device is not considered disabled during OOBE when it is |
| +// explicitly marked as not disabled. |
| +TEST_F(DeviceDisablingManagerTest, NotDisabledWhenExplicitlyNotDisabled) { |
| + SetDeviceDisabled(false); |
| + CheckWhetherDeviceDisabledDuringOOBE(); |
| + EXPECT_FALSE(IsDeviceDisabled()); |
| +} |
| + |
| +// Verifies that the device is not considered disabled during OOBE when device |
| +// disabling is turned off by flag, even if the device is marked as disabled. |
| +TEST_F(DeviceDisablingManagerTest, NotDisabledWhenTurnedOffByFlag) { |
| + CommandLine::ForCurrentProcess()->AppendSwitch( |
| + switches::kDisableDeviceDisabling); |
| + SetDeviceDisabled(true); |
| + CheckWhetherDeviceDisabledDuringOOBE(); |
| + EXPECT_FALSE(IsDeviceDisabled()); |
| +} |
| + |
| +// Verifies that the device is not considered disabled during OOBE when it is |
| +// already enrolled, even if the device is marked as disabled. |
| +TEST_F(DeviceDisablingManagerTest, DoNotShowWhenEnterpriseOwned) { |
| + SetDeviceMode(policy::DEVICE_MODE_ENTERPRISE); |
| + SetDeviceDisabled(true); |
| + CheckWhetherDeviceDisabledDuringOOBE(); |
| + EXPECT_FALSE(IsDeviceDisabled()); |
| +} |
| + |
| +// Verifies that the device is not considered disabled during OOBE when it is |
| +// already owned by a consumer, even if the device is marked as disabled. |
| +TEST_F(DeviceDisablingManagerTest, DoNotShowWhenConsumerOwned) { |
| + SetDeviceMode(policy::DEVICE_MODE_CONSUMER); |
| + SetDeviceDisabled(true); |
| + CheckWhetherDeviceDisabledDuringOOBE(); |
| + EXPECT_FALSE(IsDeviceDisabled()); |
| +} |
| + |
| +// Verifies that the device is considered disabled during OOBE when it is marked |
| +// as disabled, device disabling is not turned off by flag and the device is not |
| +// owned yet. |
| +TEST_F(DeviceDisablingManagerTest, ShowWhenDisabledAndNotOwned) { |
| + SetDeviceDisabled(true); |
| + CheckWhetherDeviceDisabledDuringOOBE(); |
| + EXPECT_TRUE(IsDeviceDisabled()); |
| + EXPECT_EQ(kDisabledMessage, GetDisabledMessage()); |
| +} |
| + |
| +} // namespace system |
| +} // namespace chromeos |