Index: chrome/browser/chromeos/login/screens/device_disabled_screen_unittest.cc |
diff --git a/chrome/browser/chromeos/login/screens/device_disabled_screen_unittest.cc b/chrome/browser/chromeos/login/screens/device_disabled_screen_unittest.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..bbe2a33c91c0125eb7eb9248af977a36da9fb129 |
--- /dev/null |
+++ b/chrome/browser/chromeos/login/screens/device_disabled_screen_unittest.cc |
@@ -0,0 +1,214 @@ |
+// 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/login/screens/device_disabled_screen.h" |
+ |
+#include "base/command_line.h" |
+#include "base/macros.h" |
+#include "base/memory/scoped_ptr.h" |
+#include "base/prefs/scoped_user_pref_update.h" |
+#include "base/prefs/testing_pref_service.h" |
+#include "chrome/browser/browser_process_platform_part.h" |
+#include "chrome/browser/chromeos/login/screens/mock_device_disabled_screen_actor.h" |
+#include "chrome/browser/chromeos/login/screens/screen_observer.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/gmock/include/gmock/gmock.h" |
+#include "testing/gtest/include/gtest/gtest.h" |
+ |
+using ::testing::_; |
+ |
+namespace chromeos { |
+ |
+namespace { |
+ |
+const char kDisabledMessage[] = "Device disabled."; |
+ |
+} |
+ |
+class DeviceDisabledScreenTest : public testing::Test, public ScreenObserver { |
+ public: |
+ DeviceDisabledScreenTest(); |
+ ~DeviceDisabledScreenTest() override; |
+ |
+ // testing::Test: |
+ void SetUp() override; |
+ void TearDown() override; |
+ |
+ // ScreenObserver: |
+ MOCK_METHOD1(OnExit, void(ExitCodes)); |
+ void ShowCurrentScreen() override; |
+ void OnSetUserNamePassword(const std::string& username, |
+ const std::string& password) override; |
+ void SetUsageStatisticsReporting(bool val) override; |
+ bool GetUsageStatisticsReporting() const override; |
+ void SetHostConfiguration() override; |
+ void ConfigureHost(bool accepted_eula, |
+ const std::string& lang, |
+ const std::string& timezone, |
+ bool send_reports, |
+ const std::string& keyboard_layout) override; |
+ ErrorScreen* GetErrorScreen() override; |
+ void ShowErrorScreen() override; |
+ void HideErrorScreen(BaseScreen* parent_screen) override; |
+ |
+ void SetDeviceDisabled(bool disabled); |
+ void SetDeviceMode(policy::DeviceMode device_mode); |
+ |
+ void ExpectScreenToNotShow(); |
+ void ExpectScreenToShow(); |
+ |
+ void TryToShowScreen(); |
+ |
+ private: |
+ scoped_ptr<DeviceDisabledScreen> screen_; |
+ scoped_ptr<MockDeviceDisabledScreenActor> actor_; |
+ TestingPrefServiceSimple local_state_; |
+ policy::ScopedStubEnterpriseInstallAttributes install_attributes_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(DeviceDisabledScreenTest); |
+}; |
+ |
+DeviceDisabledScreenTest::DeviceDisabledScreenTest() |
+ : install_attributes_("", "", "", policy::DEVICE_MODE_NOT_SET) { |
+} |
+ |
+DeviceDisabledScreenTest::~DeviceDisabledScreenTest() { |
+} |
+ |
+void DeviceDisabledScreenTest::SetUp() { |
+ TestingBrowserProcess::GetGlobal()->SetLocalState(&local_state_); |
+ policy::DeviceCloudPolicyManagerChromeOS::RegisterPrefs( |
+ local_state_.registry()); |
+ |
+ actor_.reset(new MockDeviceDisabledScreenActor); |
+ screen_.reset(new DeviceDisabledScreen(this, actor_.get())); |
+} |
+ |
+void DeviceDisabledScreenTest::TearDown() { |
+ TestingBrowserProcess::GetGlobal()->SetLocalState(nullptr); |
+} |
+ |
+void DeviceDisabledScreenTest::ShowCurrentScreen() { |
+} |
+ |
+void DeviceDisabledScreenTest::OnSetUserNamePassword( |
+ const std::string& username, |
+ const std::string& password) { |
+} |
+ |
+void DeviceDisabledScreenTest::SetUsageStatisticsReporting(bool val) { |
+} |
+ |
+bool DeviceDisabledScreenTest::GetUsageStatisticsReporting() const { |
+ return false; |
+} |
+ |
+void DeviceDisabledScreenTest::SetHostConfiguration() { |
+} |
+ |
+void DeviceDisabledScreenTest::ConfigureHost( |
+ bool accepted_eula, |
+ const std::string& lang, |
+ const std::string& timezone, |
+ bool send_reports, |
+ const std::string& keyboard_layout) { |
+} |
+ |
+ErrorScreen* DeviceDisabledScreenTest::GetErrorScreen() { |
+ return nullptr; |
+} |
+ |
+void DeviceDisabledScreenTest::ShowErrorScreen() { |
+} |
+ |
+void DeviceDisabledScreenTest::HideErrorScreen(BaseScreen* parent_screen) { |
+} |
+ |
+void DeviceDisabledScreenTest::SetDeviceDisabled(bool disabled) { |
+ DictionaryPrefUpdate dict(&local_state_, prefs::kServerBackedDeviceState); |
+ dict->SetBoolean(policy::kDeviceStateDisabled, disabled); |
+ if (disabled) |
+ dict->SetString(policy::kDeviceStateDisabledMessage, kDisabledMessage); |
+} |
+ |
+void DeviceDisabledScreenTest::SetDeviceMode(policy::DeviceMode device_mode) { |
+ reinterpret_cast<policy::StubEnterpriseInstallAttributes*>( |
+ TestingBrowserProcess::GetGlobal()->platform_part()-> |
+ browser_policy_connector_chromeos()->GetInstallAttributes())-> |
+ SetMode(device_mode); |
+} |
+ |
+void DeviceDisabledScreenTest::ExpectScreenToNotShow() { |
+ EXPECT_CALL(*actor_, Show(_)).Times(0); |
+ EXPECT_CALL(*this, OnExit(ScreenObserver::DEVICE_NOT_DISABLED)).Times(1); |
+} |
+ |
+void DeviceDisabledScreenTest::ExpectScreenToShow() { |
+ EXPECT_CALL(*actor_, Show(kDisabledMessage)).Times(1); |
+ EXPECT_CALL(*this, OnExit(ScreenObserver::DEVICE_NOT_DISABLED)).Times(0); |
+} |
+ |
+void DeviceDisabledScreenTest::TryToShowScreen() { |
+ screen_->Show(); |
+} |
+ |
+// Verifies that the device disabled screen is not shown by default. |
+TEST_F(DeviceDisabledScreenTest, DoNotShowByDefault) { |
+ ExpectScreenToNotShow(); |
+ TryToShowScreen(); |
+} |
+ |
+// Verifies that the device disabled screen is not shown when the device is |
+// explicitly marked as not disabled. |
+TEST_F(DeviceDisabledScreenTest, DoNotShowWhenNotDisabled) { |
+ SetDeviceDisabled(false); |
+ ExpectScreenToNotShow(); |
+ TryToShowScreen(); |
+} |
+ |
+// Verifies that the device disabled screen is not shown when device disabling |
+// is turned off by flag, even if the device is marked as disabled. |
+TEST_F(DeviceDisabledScreenTest, DoNotShowWhenTurnedOffByFlag) { |
+ CommandLine::ForCurrentProcess()->AppendSwitch( |
+ switches::kDisableDeviceDisabling); |
+ SetDeviceDisabled(true); |
+ ExpectScreenToNotShow(); |
+ TryToShowScreen(); |
+} |
+ |
+// Verifies that the device disabled screen is not shown when the device is |
+// already enrolled, even if the device is marked as disabled. |
+TEST_F(DeviceDisabledScreenTest, DoNotShowWhenEnterpriseOwned) { |
+ SetDeviceMode(policy::DEVICE_MODE_ENTERPRISE); |
+ SetDeviceDisabled(true); |
+ ExpectScreenToNotShow(); |
+ TryToShowScreen(); |
+} |
+ |
+// Verifies that the device disabled screen is not shown when the device is |
+// already owned by a consumer, even if the device is marked as disabled. |
+TEST_F(DeviceDisabledScreenTest, DoNotShowWhenConsumerOwned) { |
+ SetDeviceMode(policy::DEVICE_MODE_CONSUMER); |
+ SetDeviceDisabled(true); |
+ ExpectScreenToNotShow(); |
+ TryToShowScreen(); |
+} |
+ |
+// Verifies that the device disabled screen is shown when the device is marked |
+// as disabled, device disabling is not turned off by flag and the device is not |
+// owned yet. |
+TEST_F(DeviceDisabledScreenTest, ShowWhenDisabledAndNotOwned) { |
+ SetDeviceDisabled(true); |
+ ExpectScreenToShow(); |
+ TryToShowScreen(); |
+} |
+ |
+} // namespace chromeos |