diff options
Diffstat (limited to 'chromium/components/policy/test_support/request_handler_for_register_device_and_user_unittest.cc')
-rw-r--r-- | chromium/components/policy/test_support/request_handler_for_register_device_and_user_unittest.cc | 244 |
1 files changed, 244 insertions, 0 deletions
diff --git a/chromium/components/policy/test_support/request_handler_for_register_device_and_user_unittest.cc b/chromium/components/policy/test_support/request_handler_for_register_device_and_user_unittest.cc new file mode 100644 index 00000000000..51cb7828d1b --- /dev/null +++ b/chromium/components/policy/test_support/request_handler_for_register_device_and_user_unittest.cc @@ -0,0 +1,244 @@ +// Copyright 2021 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 "base/strings/strcat.h" +#include "components/policy/test_support/request_handler_for_register_browser.h" + +#include "components/policy/core/common/cloud/cloud_policy_constants.h" +#include "components/policy/test_support/client_storage.h" +#include "components/policy/test_support/embedded_policy_test_server_test_base.h" +#include "components/policy/test_support/policy_storage.h" +#include "device_management_backend.pb.h" +#include "net/http/http_status_code.h" +#include "testing/gtest/include/gtest/gtest.h" + +namespace em = enterprise_management; + +namespace policy { + +namespace { + +constexpr char kDeviceId[] = "fake_device_id"; +constexpr char kAllowedUserEmail[] = "user@example.com"; +constexpr char kDisallowedUserEmail[] = "invalid-user@example.com"; +constexpr char kAllowedUserOAuthToken[] = "oauth-token-for-user"; +constexpr char kDisallowedUserOAuthToken[] = "oauth-token-for-invalid-user"; +constexpr char kMachineModel[] = "iPhone 10"; +constexpr char kBrandCode[] = "iPhone"; +constexpr char kMachineId[] = "11123"; + +} // namespace + +class RequestHandlerForRegisterDeviceAndUserTest + : public EmbeddedPolicyTestServerTestBase { + protected: + RequestHandlerForRegisterDeviceAndUserTest() = default; + ~RequestHandlerForRegisterDeviceAndUserTest() override = default; + + void SetUp() override { + EmbeddedPolicyTestServerTestBase::SetUp(); + + SetRequestTypeParam(dm_protocol::kValueRequestRegister); + SetAppType(dm_protocol::kValueAppType); + SetDeviceIdParam(kDeviceId); + SetDeviceType(dm_protocol::kValueDeviceType); + } +}; + +TEST_F(RequestHandlerForRegisterDeviceAndUserTest, + HandleRequest_NoEnrollmentToken) { + StartRequestAndWait(); + + EXPECT_EQ(GetResponseCode(), net::HTTP_UNAUTHORIZED); + + EXPECT_EQ(client_storage()->GetNumberOfRegisteredClients(), 0u); +} + +TEST_F(RequestHandlerForRegisterDeviceAndUserTest, + HandleRequest_NoManagedUsers) { + SetGoogleLoginTokenHeader(kAllowedUserOAuthToken); + + StartRequestAndWait(); + + EXPECT_EQ(GetResponseCode(), net::HTTP_INTERNAL_SERVER_ERROR); + + EXPECT_EQ(client_storage()->GetNumberOfRegisteredClients(), 0u); +} + +TEST_F(RequestHandlerForRegisterDeviceAndUserTest, + HandleRequest_UserNotAllowed) { + policy_storage()->add_managed_user(kAllowedUserEmail); + SetGoogleLoginTokenHeader(kDisallowedUserOAuthToken); + policy_storage()->set_policy_user(kDisallowedUserEmail); + + StartRequestAndWait(); + + EXPECT_EQ(GetResponseCode(), net::HTTP_FORBIDDEN); + + EXPECT_EQ(client_storage()->GetNumberOfRegisteredClients(), 0u); +} + +TEST_F(RequestHandlerForRegisterDeviceAndUserTest, HandleRequest_Success) { + policy_storage()->add_managed_user(kAllowedUserEmail); + SetGoogleLoginTokenHeader(kAllowedUserOAuthToken); + policy_storage()->set_policy_user(kAllowedUserEmail); + policy_storage()->SetPsmEntry( + base::StrCat({kBrandCode, "_", kMachineId}), + PolicyStorage::PsmEntry{ + .psm_execution_result = + em::DeviceRegisterRequest::PSM_RESULT_SUCCESSFUL_WITH_STATE, + .psm_determination_timestamp = 42}); + + em::DeviceManagementRequest device_management_request; + em::DeviceRegisterRequest* register_request = + device_management_request.mutable_register_request(); + register_request->set_machine_model(kMachineModel); + register_request->set_type(em::DeviceRegisterRequest::USER); + register_request->set_brand_code(kBrandCode); + register_request->set_machine_id(kMachineId); + register_request->set_psm_execution_result( + em::DeviceRegisterRequest::PSM_RESULT_SUCCESSFUL_WITH_STATE); + register_request->set_psm_determination_timestamp_ms(42); + SetPayload(device_management_request); + + StartRequestAndWait(); + + EXPECT_EQ(GetResponseCode(), net::HTTP_OK); + + ASSERT_TRUE(HasResponseBody()); + em::DeviceManagementResponse device_management_response = + GetDeviceManagementResponse(); + const em::DeviceRegisterResponse& register_response = + device_management_response.register_response(); + EXPECT_FALSE(register_response.device_management_token().empty()); + EXPECT_FALSE(register_response.machine_name().empty()); + EXPECT_EQ(register_response.enrollment_type(), + em::DeviceRegisterResponse::ENTERPRISE); + + ASSERT_EQ(client_storage()->GetNumberOfRegisteredClients(), 1u); + const ClientStorage::ClientInfo* client_info = + client_storage()->GetClientOrNull(kDeviceId); + ASSERT_NE(client_info, nullptr); + EXPECT_EQ(client_info->device_id, kDeviceId); + EXPECT_EQ(client_info->device_token, + register_response.device_management_token()); + EXPECT_EQ(client_info->machine_name, register_response.machine_name()); + EXPECT_EQ(client_info->username, kAllowedUserEmail); + EXPECT_FALSE(client_info->allowed_policy_types.empty()); +} + +TEST_F(RequestHandlerForRegisterDeviceAndUserTest, + HandleRequest_NoPsmExecutionResult) { + policy_storage()->add_managed_user(kAllowedUserEmail); + SetGoogleLoginTokenHeader(kAllowedUserOAuthToken); + policy_storage()->set_policy_user(kAllowedUserEmail); + policy_storage()->SetPsmEntry( + base::StrCat({kBrandCode, "_", kMachineId}), + PolicyStorage::PsmEntry{ + .psm_execution_result = + em::DeviceRegisterRequest::PSM_RESULT_SUCCESSFUL_WITH_STATE, + .psm_determination_timestamp = 42}); + + em::DeviceManagementRequest device_management_request; + em::DeviceRegisterRequest* register_request = + device_management_request.mutable_register_request(); + register_request->set_machine_model(kMachineModel); + register_request->set_type(em::DeviceRegisterRequest::USER); + register_request->set_brand_code(kBrandCode); + register_request->set_machine_id(kMachineId); + register_request->set_psm_determination_timestamp_ms(42); + SetPayload(device_management_request); + + StartRequestAndWait(); + + EXPECT_EQ(GetResponseCode(), net::HTTP_BAD_REQUEST); +} + +TEST_F(RequestHandlerForRegisterDeviceAndUserTest, + HandleRequest_NoPsmDeterminationTimestamp) { + policy_storage()->add_managed_user(kAllowedUserEmail); + SetGoogleLoginTokenHeader(kAllowedUserOAuthToken); + policy_storage()->set_policy_user(kAllowedUserEmail); + policy_storage()->SetPsmEntry( + base::StrCat({kBrandCode, "_", kMachineId}), + PolicyStorage::PsmEntry{ + .psm_execution_result = + em::DeviceRegisterRequest::PSM_RESULT_SUCCESSFUL_WITH_STATE, + .psm_determination_timestamp = 42}); + + em::DeviceManagementRequest device_management_request; + em::DeviceRegisterRequest* register_request = + device_management_request.mutable_register_request(); + register_request->set_machine_model(kMachineModel); + register_request->set_type(em::DeviceRegisterRequest::USER); + register_request->set_brand_code(kBrandCode); + register_request->set_machine_id(kMachineId); + register_request->set_psm_execution_result( + em::DeviceRegisterRequest::PSM_RESULT_SUCCESSFUL_WITH_STATE); + SetPayload(device_management_request); + + StartRequestAndWait(); + + EXPECT_EQ(GetResponseCode(), net::HTTP_BAD_REQUEST); +} + +TEST_F(RequestHandlerForRegisterDeviceAndUserTest, + HandleRequest_MismatchingPsmExecutionResult) { + policy_storage()->add_managed_user(kAllowedUserEmail); + SetGoogleLoginTokenHeader(kAllowedUserOAuthToken); + policy_storage()->set_policy_user(kAllowedUserEmail); + policy_storage()->SetPsmEntry( + base::StrCat({kBrandCode, "_", kMachineId}), + PolicyStorage::PsmEntry{ + .psm_execution_result = + em::DeviceRegisterRequest::PSM_RESULT_SUCCESSFUL_WITH_STATE, + .psm_determination_timestamp = 42}); + + em::DeviceManagementRequest device_management_request; + em::DeviceRegisterRequest* register_request = + device_management_request.mutable_register_request(); + register_request->set_machine_model(kMachineModel); + register_request->set_type(em::DeviceRegisterRequest::USER); + register_request->set_brand_code(kBrandCode); + register_request->set_machine_id(kMachineId); + register_request->set_psm_execution_result( + em::DeviceRegisterRequest::PSM_RESULT_SUCCESSFUL_WITHOUT_STATE); + register_request->set_psm_determination_timestamp_ms(42); + SetPayload(device_management_request); + + StartRequestAndWait(); + + EXPECT_EQ(GetResponseCode(), net::HTTP_BAD_REQUEST); +} + +TEST_F(RequestHandlerForRegisterDeviceAndUserTest, + HandleRequest_MismatchingPsmDeterminationTimestamp) { + policy_storage()->add_managed_user(kAllowedUserEmail); + SetGoogleLoginTokenHeader(kAllowedUserOAuthToken); + policy_storage()->set_policy_user(kAllowedUserEmail); + policy_storage()->SetPsmEntry( + base::StrCat({kBrandCode, "_", kMachineId}), + PolicyStorage::PsmEntry{ + .psm_execution_result = + em::DeviceRegisterRequest::PSM_RESULT_SUCCESSFUL_WITH_STATE, + .psm_determination_timestamp = 42}); + + em::DeviceManagementRequest device_management_request; + em::DeviceRegisterRequest* register_request = + device_management_request.mutable_register_request(); + register_request->set_machine_model(kMachineModel); + register_request->set_type(em::DeviceRegisterRequest::USER); + register_request->set_brand_code(kBrandCode); + register_request->set_machine_id(kMachineId); + register_request->set_psm_execution_result( + em::DeviceRegisterRequest::PSM_RESULT_SUCCESSFUL_WITHOUT_STATE); + register_request->set_psm_determination_timestamp_ms(24); + SetPayload(device_management_request); + + StartRequestAndWait(); + + EXPECT_EQ(GetResponseCode(), net::HTTP_BAD_REQUEST); +} + +} // namespace policy |