| Index: chrome/browser/chromeos/login/managed/managed_user_test_base.cc
|
| diff --git a/chrome/browser/chromeos/login/managed/managed_user_test_base.cc b/chrome/browser/chromeos/login/managed/managed_user_test_base.cc
|
| deleted file mode 100644
|
| index 6995ec986411b54cda3eb795e5745a3f9a72292a..0000000000000000000000000000000000000000
|
| --- a/chrome/browser/chromeos/login/managed/managed_user_test_base.cc
|
| +++ /dev/null
|
| @@ -1,436 +0,0 @@
|
| -// 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/managed/managed_user_test_base.h"
|
| -
|
| -#include <string>
|
| -
|
| -#include "base/compiler_specific.h"
|
| -#include "base/run_loop.h"
|
| -#include "base/strings/string_number_conversions.h"
|
| -#include "base/strings/stringprintf.h"
|
| -#include "base/strings/utf_string_conversions.h"
|
| -#include "base/threading/sequenced_worker_pool.h"
|
| -#include "chrome/browser/chrome_notification_types.h"
|
| -#include "chrome/browser/chromeos/login/login_manager_test.h"
|
| -#include "chrome/browser/chromeos/login/managed/supervised_user_authentication.h"
|
| -#include "chrome/browser/chromeos/login/startup_utils.h"
|
| -#include "chrome/browser/chromeos/login/ui/login_display_host_impl.h"
|
| -#include "chrome/browser/chromeos/login/ui/webui_login_view.h"
|
| -#include "chrome/browser/chromeos/login/users/supervised_user_manager.h"
|
| -#include "chrome/browser/chromeos/net/network_portal_detector_test_impl.h"
|
| -#include "chrome/browser/chromeos/profiles/profile_helper.h"
|
| -#include "chrome/browser/chromeos/settings/stub_cros_settings_provider.h"
|
| -#include "chrome/browser/profiles/profile_impl.h"
|
| -#include "chrome/browser/supervised_user/supervised_user_constants.h"
|
| -#include "chrome/browser/supervised_user/supervised_user_registration_utility.h"
|
| -#include "chrome/browser/supervised_user/supervised_user_registration_utility_stub.h"
|
| -#include "chrome/browser/supervised_user/supervised_user_shared_settings_service.h"
|
| -#include "chrome/browser/supervised_user/supervised_user_shared_settings_service_factory.h"
|
| -#include "chrome/browser/supervised_user/supervised_user_sync_service.h"
|
| -#include "chrome/browser/supervised_user/supervised_user_sync_service_factory.h"
|
| -#include "chromeos/cryptohome/mock_async_method_caller.h"
|
| -#include "chromeos/cryptohome/mock_homedir_methods.h"
|
| -#include "chromeos/login/auth/key.h"
|
| -#include "chromeos/login/auth/user_context.h"
|
| -#include "content/public/browser/notification_service.h"
|
| -#include "content/public/test/browser_test_utils.h"
|
| -#include "content/public/test/test_utils.h"
|
| -#include "sync/api/attachments/attachment_service_proxy_for_test.h"
|
| -#include "sync/api/fake_sync_change_processor.h"
|
| -#include "sync/api/sync_change.h"
|
| -#include "sync/api/sync_error_factory_mock.h"
|
| -#include "sync/protocol/sync.pb.h"
|
| -
|
| -using testing::_;
|
| -using base::StringPrintf;
|
| -
|
| -namespace chromeos {
|
| -
|
| -namespace {
|
| -
|
| -const char kCurrentPage[] = "$('managed-user-creation').currentPage_";
|
| -
|
| -const char kStubEthernetGuid[] = "eth0";
|
| -
|
| -}
|
| -
|
| -ManagedUsersSyncTestAdapter::ManagedUsersSyncTestAdapter(Profile* profile)
|
| - : processor_(), next_sync_data_id_(0) {
|
| - service_ = SupervisedUserSyncServiceFactory::GetForProfile(profile);
|
| - processor_ = new syncer::FakeSyncChangeProcessor();
|
| - service_->MergeDataAndStartSyncing(
|
| - syncer::SUPERVISED_USERS,
|
| - syncer::SyncDataList(),
|
| - scoped_ptr<syncer::SyncChangeProcessor>(processor_),
|
| - scoped_ptr<syncer::SyncErrorFactory>(new syncer::SyncErrorFactoryMock));
|
| -}
|
| -
|
| -scoped_ptr< ::sync_pb::ManagedUserSpecifics>
|
| -ManagedUsersSyncTestAdapter::GetFirstChange() {
|
| - scoped_ptr< ::sync_pb::ManagedUserSpecifics> result(
|
| - new ::sync_pb::ManagedUserSpecifics);
|
| - CHECK(HasChanges())
|
| - << "GetFirstChange() should only be callled if HasChanges() is true";
|
| - const syncer::SyncData& data = processor_->changes().front().sync_data();
|
| - EXPECT_EQ(syncer::SUPERVISED_USERS, data.GetDataType());
|
| - result->CopyFrom(data.GetSpecifics().managed_user());
|
| - return result.Pass();
|
| -}
|
| -
|
| -void ManagedUsersSyncTestAdapter::AddChange(
|
| - const ::sync_pb::ManagedUserSpecifics& proto,
|
| - bool update) {
|
| - sync_pb::EntitySpecifics specifics;
|
| -
|
| - specifics.mutable_managed_user()->CopyFrom(proto);
|
| -
|
| - syncer::SyncData change_data = syncer::SyncData::CreateRemoteData(
|
| - ++next_sync_data_id_,
|
| - specifics,
|
| - base::Time(),
|
| - syncer::AttachmentIdList(),
|
| - syncer::AttachmentServiceProxyForTest::Create());
|
| - syncer::SyncChange change(FROM_HERE,
|
| - update ? syncer::SyncChange::ACTION_UPDATE
|
| - : syncer::SyncChange::ACTION_ADD,
|
| - change_data);
|
| -
|
| - syncer::SyncChangeList change_list;
|
| - change_list.push_back(change);
|
| -
|
| - service_->ProcessSyncChanges(FROM_HERE, change_list);
|
| -}
|
| -
|
| -ManagedUsersSharedSettingsSyncTestAdapter::
|
| - ManagedUsersSharedSettingsSyncTestAdapter(Profile* profile)
|
| - : processor_(), next_sync_data_id_(0) {
|
| - service_ =
|
| - SupervisedUserSharedSettingsServiceFactory::GetForBrowserContext(profile);
|
| - processor_ = new syncer::FakeSyncChangeProcessor();
|
| - service_->MergeDataAndStartSyncing(
|
| - syncer::SUPERVISED_USER_SHARED_SETTINGS,
|
| - syncer::SyncDataList(),
|
| - scoped_ptr<syncer::SyncChangeProcessor>(processor_),
|
| - scoped_ptr<syncer::SyncErrorFactory>(new syncer::SyncErrorFactoryMock));
|
| -}
|
| -
|
| -scoped_ptr< ::sync_pb::ManagedUserSharedSettingSpecifics>
|
| -ManagedUsersSharedSettingsSyncTestAdapter::GetFirstChange() {
|
| - scoped_ptr< ::sync_pb::ManagedUserSharedSettingSpecifics> result(
|
| - new ::sync_pb::ManagedUserSharedSettingSpecifics);
|
| - CHECK(HasChanges())
|
| - << "GetFirstChange() should only be callled if HasChanges() is true";
|
| - const syncer::SyncData& data = processor_->changes().front().sync_data();
|
| - EXPECT_EQ(syncer::SUPERVISED_USER_SHARED_SETTINGS, data.GetDataType());
|
| - result->CopyFrom(data.GetSpecifics().managed_user_shared_setting());
|
| - return result.Pass();
|
| -}
|
| -
|
| -void ManagedUsersSharedSettingsSyncTestAdapter::AddChange(
|
| - const ::sync_pb::ManagedUserSharedSettingSpecifics& proto,
|
| - bool update) {
|
| - sync_pb::EntitySpecifics specifics;
|
| -
|
| - specifics.mutable_managed_user_shared_setting()->CopyFrom(proto);
|
| -
|
| - syncer::SyncData change_data = syncer::SyncData::CreateRemoteData(
|
| - ++next_sync_data_id_,
|
| - specifics,
|
| - base::Time(),
|
| - syncer::AttachmentIdList(),
|
| - syncer::AttachmentServiceProxyForTest::Create());
|
| - syncer::SyncChange change(FROM_HERE,
|
| - update ? syncer::SyncChange::ACTION_UPDATE
|
| - : syncer::SyncChange::ACTION_ADD,
|
| - change_data);
|
| -
|
| - syncer::SyncChangeList change_list;
|
| - change_list.push_back(change);
|
| -
|
| - service_->ProcessSyncChanges(FROM_HERE, change_list);
|
| -}
|
| -
|
| -void ManagedUsersSharedSettingsSyncTestAdapter::AddChange(
|
| - const std::string& mu_id,
|
| - const std::string& key,
|
| - const base::Value& value,
|
| - bool acknowledged,
|
| - bool update) {
|
| - syncer::SyncData data =
|
| - SupervisedUserSharedSettingsService::CreateSyncDataForSetting(
|
| - mu_id, key, value, acknowledged);
|
| - AddChange(data.GetSpecifics().managed_user_shared_setting(), update);
|
| -}
|
| -
|
| -ManagedUserTestBase::ManagedUserTestBase()
|
| - : LoginManagerTest(true),
|
| - mock_async_method_caller_(NULL),
|
| - mock_homedir_methods_(NULL),
|
| - network_portal_detector_(NULL),
|
| - registration_utility_stub_(NULL) {
|
| -}
|
| -
|
| -ManagedUserTestBase::~ManagedUserTestBase() {
|
| -}
|
| -
|
| -void ManagedUserTestBase::SetUpInProcessBrowserTestFixture() {
|
| - LoginManagerTest::SetUpInProcessBrowserTestFixture();
|
| - mock_async_method_caller_ = new cryptohome::MockAsyncMethodCaller;
|
| - mock_async_method_caller_->SetUp(true, cryptohome::MOUNT_ERROR_NONE);
|
| - cryptohome::AsyncMethodCaller::InitializeForTesting(
|
| - mock_async_method_caller_);
|
| -
|
| - mock_homedir_methods_ = new cryptohome::MockHomedirMethods;
|
| - mock_homedir_methods_->SetUp(true, cryptohome::MOUNT_ERROR_NONE);
|
| - cryptohome::HomedirMethods::InitializeForTesting(mock_homedir_methods_);
|
| -
|
| - registration_utility_stub_ = new SupervisedUserRegistrationUtilityStub();
|
| - scoped_utility_.reset(new ScopedTestingSupervisedUserRegistrationUtility(
|
| - registration_utility_stub_));
|
| -
|
| - // Setup network portal detector to return online state for both
|
| - // ethernet and wifi networks. Ethernet is an active network by
|
| - // default.
|
| - network_portal_detector_ = new NetworkPortalDetectorTestImpl();
|
| - NetworkPortalDetector::InitializeForTesting(network_portal_detector_);
|
| - NetworkPortalDetector::CaptivePortalState online_state;
|
| - online_state.status = NetworkPortalDetector::CAPTIVE_PORTAL_STATUS_ONLINE;
|
| - online_state.response_code = 204;
|
| - network_portal_detector_->SetDefaultNetworkForTesting(kStubEthernetGuid);
|
| - network_portal_detector_->SetDetectionResultsForTesting(kStubEthernetGuid,
|
| - online_state);
|
| -}
|
| -
|
| -void ManagedUserTestBase::CleanUpOnMainThread() {
|
| - LoginManagerTest::CleanUpOnMainThread();
|
| -}
|
| -
|
| -void ManagedUserTestBase::TearDown() {
|
| - cryptohome::AsyncMethodCaller::Shutdown();
|
| - cryptohome::HomedirMethods::Shutdown();
|
| - mock_homedir_methods_ = NULL;
|
| - mock_async_method_caller_ = NULL;
|
| - LoginManagerTest::TearDown();
|
| -}
|
| -
|
| -void ManagedUserTestBase::TearDownInProcessBrowserTestFixture() {
|
| - NetworkPortalDetector::Shutdown();
|
| -}
|
| -
|
| -void ManagedUserTestBase::JSEval(const std::string& script) {
|
| - EXPECT_TRUE(content::ExecuteScript(web_contents(), script)) << script;
|
| -}
|
| -
|
| -void ManagedUserTestBase::JSExpectAsync(const std::string& function) {
|
| - bool result;
|
| - EXPECT_TRUE(content::ExecuteScriptAndExtractBool(
|
| - web_contents(),
|
| - StringPrintf(
|
| - "(%s)(function() { window.domAutomationController.send(true); });",
|
| - function.c_str()),
|
| - &result)) << function;
|
| - EXPECT_TRUE(result);
|
| -}
|
| -
|
| -void ManagedUserTestBase::JSSetTextField(const std::string& element_selector,
|
| - const std::string& value) {
|
| - std::string function =
|
| - StringPrintf("document.querySelector('%s').value = '%s'",
|
| - element_selector.c_str(),
|
| - value.c_str());
|
| - JSEval(function);
|
| -}
|
| -
|
| -void ManagedUserTestBase::PrepareUsers() {
|
| - RegisterUser(kTestManager);
|
| - RegisterUser(kTestOtherUser);
|
| - chromeos::StartupUtils::MarkOobeCompleted();
|
| -}
|
| -
|
| -void ManagedUserTestBase::StartFlowLoginAsManager() {
|
| - // Navigate to supervised user creation screen.
|
| - JSEval("chrome.send('showLocallyManagedUserCreationScreen')");
|
| -
|
| - // Read intro and proceed.
|
| - JSExpect(StringPrintf("%s == 'intro'", kCurrentPage));
|
| -
|
| - JSEval("$('managed-user-creation-start-button').click()");
|
| -
|
| - // Check that both users appear as managers, and test-manager@gmail.com is
|
| - // the first one.
|
| - JSExpect(StringPrintf("%s == 'manager'", kCurrentPage));
|
| -
|
| - std::string manager_pods =
|
| - "document.querySelectorAll('#managed-user-creation-managers-pane "
|
| - ".manager-pod')";
|
| - std::string selected_manager_pods =
|
| - "document.querySelectorAll('#managed-user-creation-managers-pane "
|
| - ".manager-pod.focused')";
|
| -
|
| - int managers_on_device = 2;
|
| -
|
| - JSExpect(StringPrintf("%s.length == 1", selected_manager_pods.c_str()));
|
| -
|
| - JSExpect(
|
| - StringPrintf("$('managed-user-creation').managerList_.pods.length == %d",
|
| - managers_on_device));
|
| - JSExpect(StringPrintf(
|
| - "%s.length == %d", manager_pods.c_str(), managers_on_device));
|
| - JSExpect(StringPrintf("%s[%d].user.emailAddress == '%s'",
|
| - manager_pods.c_str(),
|
| - 0,
|
| - kTestManager));
|
| -
|
| - // Select the first user as manager, and enter password.
|
| - JSExpect("$('managed-user-creation-next-button').disabled");
|
| - JSSetTextField("#managed-user-creation .manager-pod.focused input",
|
| - kTestManagerPassword);
|
| -
|
| - JSEval("$('managed-user-creation').updateNextButtonForManager_()");
|
| -
|
| - // Next button is now enabled.
|
| - JSExpect("!$('managed-user-creation-next-button').disabled");
|
| - UserContext user_context(kTestManager);
|
| - user_context.SetKey(Key(kTestManagerPassword));
|
| - SetExpectedCredentials(user_context);
|
| - content::WindowedNotificationObserver login_observer(
|
| - chrome::NOTIFICATION_LOGIN_USER_PROFILE_PREPARED,
|
| - content::NotificationService::AllSources());
|
| -
|
| - // Log in as manager.
|
| - JSEval("$('managed-user-creation-next-button').click()");
|
| - login_observer.Wait();
|
| -
|
| - // OAuth token is valid.
|
| - UserManager::Get()->SaveUserOAuthStatus(kTestManager,
|
| - User::OAUTH2_TOKEN_STATUS_VALID);
|
| - base::RunLoop().RunUntilIdle();
|
| -
|
| - // Check the page have changed.
|
| - JSExpect(StringPrintf("%s == 'username'", kCurrentPage));
|
| -}
|
| -
|
| -void ManagedUserTestBase::FillNewUserData(const std::string& display_name) {
|
| - JSExpect("$('managed-user-creation-next-button').disabled");
|
| - JSSetTextField("#managed-user-creation-name", display_name);
|
| - JSEval("$('managed-user-creation').checkUserName_()");
|
| -
|
| - base::RunLoop().RunUntilIdle();
|
| -
|
| - JSSetTextField("#managed-user-creation-password",
|
| - kTestSupervisedUserPassword);
|
| - JSSetTextField("#managed-user-creation-password-confirm",
|
| - kTestSupervisedUserPassword);
|
| -
|
| - JSEval("$('managed-user-creation').updateNextButtonForUser_()");
|
| - JSExpect("!$('managed-user-creation-next-button').disabled");
|
| -}
|
| -
|
| -void ManagedUserTestBase::StartUserCreation(
|
| - const std::string& button_id,
|
| - const std::string& expected_display_name) {
|
| - EXPECT_CALL(*mock_homedir_methods_, MountEx(_, _, _, _)).Times(1);
|
| - EXPECT_CALL(*mock_homedir_methods_, AddKeyEx(_, _, _, _, _)).Times(1);
|
| -
|
| - JSEval(std::string("$('").append(button_id).append("').click()"));
|
| -
|
| - ::testing::Mock::VerifyAndClearExpectations(mock_homedir_methods_);
|
| -
|
| - EXPECT_TRUE(registration_utility_stub_->register_was_called());
|
| - EXPECT_EQ(registration_utility_stub_->display_name(),
|
| - base::UTF8ToUTF16(expected_display_name));
|
| -
|
| - registration_utility_stub_->RunSuccessCallback("token");
|
| -
|
| - // Token writing moves control to BlockingPool and back.
|
| - base::RunLoop().RunUntilIdle();
|
| - content::BrowserThread::GetBlockingPool()->FlushForTesting();
|
| - base::RunLoop().RunUntilIdle();
|
| -
|
| - JSExpect(StringPrintf("%s == 'created'", kCurrentPage));
|
| - JSEval("$('managed-user-creation-gotit-button').click()");
|
| -}
|
| -
|
| -void ManagedUserTestBase::SigninAsSupervisedUser(
|
| - bool check_homedir_calls,
|
| - int user_index,
|
| - const std::string& expected_display_name) {
|
| - if (check_homedir_calls)
|
| - EXPECT_CALL(*mock_homedir_methods_, MountEx(_, _, _, _)).Times(1);
|
| -
|
| - // Log in as supervised user, make sure that everything works.
|
| - ASSERT_EQ(3UL, UserManager::Get()->GetUsers().size());
|
| -
|
| - // Created supervised user have to be first in a list.
|
| - const User* user = UserManager::Get()->GetUsers().at(user_index);
|
| - ASSERT_EQ(base::UTF8ToUTF16(expected_display_name), user->display_name());
|
| - LoginUser(user->email());
|
| - if (check_homedir_calls)
|
| - ::testing::Mock::VerifyAndClearExpectations(mock_homedir_methods_);
|
| - Profile* profile = ProfileHelper::Get()->GetProfileByUser(user);
|
| - shared_settings_adapter_.reset(
|
| - new ManagedUsersSharedSettingsSyncTestAdapter(profile));
|
| -
|
| - // Check ChromeOS preference is initialized.
|
| - EXPECT_TRUE(
|
| - static_cast<ProfileImpl*>(profile)->chromeos_preferences_);
|
| -}
|
| -
|
| -void ManagedUserTestBase::SigninAsManager(int user_index) {
|
| - // Log in as supervised user, make sure that everything works.
|
| - ASSERT_EQ(3UL, UserManager::Get()->GetUsers().size());
|
| -
|
| - // Created supervised user have to be first in a list.
|
| - const User* user = UserManager::Get()->GetUsers().at(user_index);
|
| - LoginUser(user->email());
|
| - Profile* profile = ProfileHelper::Get()->GetProfileByUser(user);
|
| - shared_settings_adapter_.reset(
|
| - new ManagedUsersSharedSettingsSyncTestAdapter(profile));
|
| - managed_users_adapter_.reset(new ManagedUsersSyncTestAdapter(profile));
|
| -}
|
| -
|
| -void ManagedUserTestBase::RemoveSupervisedUser(
|
| - unsigned long original_user_count,
|
| - int user_index,
|
| - const std::string& expected_display_name) {
|
| - // Remove supervised user.
|
| - ASSERT_EQ(original_user_count, UserManager::Get()->GetUsers().size());
|
| -
|
| - // Created supervised user have to be first in a list.
|
| - const User* user = UserManager::Get()->GetUsers().at(user_index);
|
| - ASSERT_EQ(base::UTF8ToUTF16(expected_display_name), user->display_name());
|
| -
|
| - // Open pod menu.
|
| - JSExpect(
|
| - StringPrintf("!$('pod-row').pods[%d].isActionBoxMenuActive", user_index));
|
| - JSEval(StringPrintf(
|
| - "$('pod-row').pods[%d].querySelector('.action-box-button').click()",
|
| - user_index));
|
| - JSExpect(
|
| - StringPrintf("$('pod-row').pods[%d].isActionBoxMenuActive", user_index));
|
| -
|
| - // Select "Remove user" element.
|
| - JSExpect(StringPrintf(
|
| - "$('pod-row').pods[%d].actionBoxRemoveUserWarningElement.hidden",
|
| - user_index));
|
| - JSEval(StringPrintf(
|
| - "$('pod-row').pods[%d].querySelector('.action-box-menu-remove').click()",
|
| - user_index));
|
| - JSExpect(StringPrintf(
|
| - "!$('pod-row').pods[%d].actionBoxRemoveUserWarningElement.hidden",
|
| - user_index));
|
| -
|
| - EXPECT_CALL(*mock_async_method_caller_, AsyncRemove(_, _)).Times(1);
|
| -
|
| - // Confirm deletion.
|
| - JSEval(StringPrintf(
|
| - "$('pod-row').pods[%d].querySelector('.remove-warning-button').click()",
|
| - user_index));
|
| -
|
| - // Make sure there is no supervised user in list.
|
| - ASSERT_EQ(original_user_count - 1, UserManager::Get()->GetUsers().size());
|
| -}
|
| -
|
| -} // namespace chromeos
|
|
|