1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103
|
// Copyright 2016 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include <memory>
#include <string>
#include "base/functional/bind.h"
#include "base/functional/callback_helpers.h"
#include "base/memory/ref_counted.h"
#include "base/run_loop.h"
#include "base/test/mock_callback.h"
#include "base/test/task_environment.h"
#include "base/time/time.h"
#include "chrome/browser/ash/policy/arc/android_management_client.h"
#include "components/policy/core/common/cloud/cloud_policy_constants.h"
#include "components/policy/core/common/cloud/mock_device_management_service.h"
#include "components/policy/proto/device_management_backend.pb.h"
#include "components/signin/public/identity_manager/identity_manager.h"
#include "components/signin/public/identity_manager/identity_test_environment.h"
#include "services/network/public/cpp/weak_wrapper_shared_url_loader_factory.h"
#include "services/network/test/test_url_loader_factory.h"
#include "testing/gmock/include/gmock/gmock.h"
#include "testing/gtest/include/gtest/gtest.h"
using testing::_;
using testing::DoAll;
using testing::SaveArg;
using testing::StrictMock;
namespace em = enterprise_management;
namespace policy {
namespace {
const char kAccountEmail[] = "fake-account-id@gmail.com";
const char kOAuthToken[] = "fake-oauth-token";
} // namespace
class AndroidManagementClientTest : public testing::Test {
protected:
AndroidManagementClientTest()
: identity_test_environment_(&url_loader_factory_) {
android_management_response_.mutable_check_android_management_response();
}
// testing::Test:
void SetUp() override {
shared_url_loader_factory_ =
base::MakeRefCounted<network::WeakWrapperSharedURLLoaderFactory>(
&url_loader_factory_);
signin::IdentityManager* identity_manager =
identity_test_environment_.identity_manager();
CoreAccountId account_id = identity_manager->PickAccountIdForAccount(
signin::GetTestGaiaIdForEmail(kAccountEmail), kAccountEmail);
client_ = std::make_unique<AndroidManagementClientImpl>(
&service_, shared_url_loader_factory_, account_id, identity_manager);
base::RunLoop().RunUntilIdle();
}
// Protobuf is used in successfil responsees.
em::DeviceManagementResponse android_management_response_;
base::test::SingleThreadTaskEnvironment task_environment_;
StrictMock<MockJobCreationHandler> job_creation_handler_;
FakeDeviceManagementService service_{&job_creation_handler_};
StrictMock<base::MockCallback<AndroidManagementClient::StatusCallback>>
callback_observer_;
std::unique_ptr<AndroidManagementClientImpl> client_;
network::TestURLLoaderFactory url_loader_factory_;
scoped_refptr<network::SharedURLLoaderFactory> shared_url_loader_factory_;
signin::IdentityTestEnvironment identity_test_environment_;
};
TEST_F(AndroidManagementClientTest, CheckAndroidManagementCall) {
DeviceManagementService::JobConfiguration::JobType job_type;
DeviceManagementService::JobConfiguration::ParameterMap params;
EXPECT_CALL(job_creation_handler_, OnJobCreation)
.WillOnce(DoAll(service_.CaptureJobType(&job_type),
service_.CaptureQueryParams(¶ms),
service_.SendJobOKAsync(android_management_response_)));
EXPECT_CALL(callback_observer_,
Run(AndroidManagementClient::Result::UNMANAGED))
.Times(1);
AccountInfo account_info =
identity_test_environment_.MakeAccountAvailable(kAccountEmail);
client_->StartCheckAndroidManagement(callback_observer_.Get());
identity_test_environment_
.WaitForAccessTokenRequestIfNecessaryAndRespondWithToken(
account_info.account_id, kOAuthToken, base::Time::Max());
base::RunLoop().RunUntilIdle();
ASSERT_EQ(
DeviceManagementService::JobConfiguration::TYPE_ANDROID_MANAGEMENT_CHECK,
job_type);
ASSERT_LT(params[dm_protocol::kParamDeviceID].size(), 64U);
}
} // namespace policy
|