blob: 33dd596280dfd05f423005bed6d977c84c672394 [file] [log] [blame]
// 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 "content/browser/aggregation_service/public_key_parsing_utils.h"
#include <string>
#include <vector>
#include "base/json/json_reader.h"
#include "base/strings/string_util.h"
#include "content/browser/aggregation_service/aggregation_service_test_utils.h"
#include "content/browser/aggregation_service/public_key.h"
#include "testing/gtest/include/gtest/gtest.h"
namespace content {
TEST(PublicKeyParsingUtilsTest, WellFormedSingleKey_ParsedCorrectly) {
aggregation_service::TestHpkeKey generated_key =
aggregation_service::GenerateKey("abcd");
std::string json_string = base::ReplaceStringPlaceholders(
R"({
"version": "",
"keys": [
{
"id": "abcd",
"key": "$1"
}
]
})",
{generated_key.base64_encoded_public_key}, /*offsets=*/nullptr);
absl::optional<base::Value> json_object = base::JSONReader::Read(json_string);
ASSERT_TRUE(json_object) << "Incorrectly formatted JSON string.";
std::vector<PublicKey> keys =
aggregation_service::GetPublicKeys(json_object.value());
EXPECT_TRUE(
aggregation_service::PublicKeysEqual({generated_key.public_key}, keys));
}
TEST(PublicKeyParsingUtilsTest, WellFormedMultipleKeys_ParsedCorrectly) {
aggregation_service::TestHpkeKey generated_key_1 =
aggregation_service::GenerateKey("abcd");
aggregation_service::TestHpkeKey generated_key_2 =
aggregation_service::GenerateKey("efgh");
std::string json_string = base::ReplaceStringPlaceholders(
R"({
"version": "",
"keys": [
{
"id": "abcd",
"key": "$1"
},
{
"id": "efgh",
"key": "$2"
}
]
})",
{generated_key_1.base64_encoded_public_key,
generated_key_2.base64_encoded_public_key},
/*offsets=*/nullptr);
absl::optional<base::Value> json_object = base::JSONReader::Read(json_string);
ASSERT_TRUE(json_object) << "Incorrectly formatted JSON string.";
std::vector<PublicKey> keys =
aggregation_service::GetPublicKeys(json_object.value());
EXPECT_TRUE(aggregation_service::PublicKeysEqual(
{generated_key_1.public_key, generated_key_2.public_key}, keys));
}
TEST(PublicKeyParsingUtilsTest, MalformedMissingId_EmptyResult) {
std::string json_string = base::ReplaceStringPlaceholders(
R"({
"version": "",
"keys": [
{
"key": "$1"
}
]
})",
{aggregation_service::GenerateKey().base64_encoded_public_key},
/*offsets=*/nullptr);
absl::optional<base::Value> json_object = base::JSONReader::Read(json_string);
ASSERT_TRUE(json_object) << "Incorrectly formatted JSON string.";
std::vector<PublicKey> keys =
aggregation_service::GetPublicKeys(json_object.value());
EXPECT_TRUE(keys.empty());
}
TEST(PublicKeyParsingUtilsTest, MalformedMissingKey_EmptyResult) {
std::string json_string = R"(
{
"version": "",
"keys": [
{
"id": "abcd"
}
]
}
)";
absl::optional<base::Value> json_object = base::JSONReader::Read(json_string);
ASSERT_TRUE(json_object) << "Incorrectly formatted JSON string.";
std::vector<PublicKey> keys =
aggregation_service::GetPublicKeys(json_object.value());
EXPECT_TRUE(keys.empty());
}
TEST(PublicKeyParsingUtilsTest, MalformedKeyNotValidBase64_EmptyResult) {
std::string invalid_base64 =
aggregation_service::GenerateKey().base64_encoded_public_key;
// Replace a character with an invalid one.
invalid_base64[5] = '-';
std::string json_string = base::ReplaceStringPlaceholders(
R"({
"version": "",
"keys": [
{
"id": "abcd",
"key": "$1"
}
]
})",
{invalid_base64}, /*offsets=*/nullptr);
absl::optional<base::Value> json_object = base::JSONReader::Read(json_string);
ASSERT_TRUE(json_object) << "Incorrectly formatted JSON string.";
std::vector<PublicKey> keys =
aggregation_service::GetPublicKeys(json_object.value());
EXPECT_TRUE(keys.empty());
}
TEST(PublicKeyParsingUtilsTest, MalformedKeyWrongLength_EmptyResult) {
std::string wrong_length_key =
aggregation_service::GenerateKey().base64_encoded_public_key;
wrong_length_key.resize(16);
std::string json_string = base::ReplaceStringPlaceholders(
R"({
"version": "",
"keys": [
{
"id": "abcd",
"key": "$1"
}
]
})",
{wrong_length_key}, /*offsets=*/nullptr);
absl::optional<base::Value> json_object = base::JSONReader::Read(json_string);
ASSERT_TRUE(json_object) << "Incorrectly formatted JSON string.";
std::vector<PublicKey> keys =
aggregation_service::GetPublicKeys(json_object.value());
EXPECT_TRUE(keys.empty());
}
TEST(PublicKeyParsingUtilsTest, WellFormedAndMalformedKeys_EmptyResult) {
std::string json_string = base::ReplaceStringPlaceholders(
R"({
"version": "",
"keys": [
{
"id": "abcd",
"key": "$1"
},
{
"id": "efgh"
}
]
}
)",
{aggregation_service::GenerateKey().base64_encoded_public_key},
/*offsets=*/nullptr);
absl::optional<base::Value> json_object = base::JSONReader::Read(json_string);
ASSERT_TRUE(json_object) << "Incorrectly formatted JSON string.";
std::vector<PublicKey> keys =
aggregation_service::GetPublicKeys(json_object.value());
EXPECT_TRUE(keys.empty());
}
TEST(PublicKeyParsingUtilsTest, MalformedKeyDuplicateKeyId_EmptyResult) {
std::string json_string = base::ReplaceStringPlaceholders(
R"({
"version": "",
"keys": [
{
"id": "abcd",
"key": "$1"
},
{
"id": "abcd",
"key": "$2"
}
]
})",
{aggregation_service::GenerateKey("abcd").base64_encoded_public_key,
aggregation_service::GenerateKey("abcd").base64_encoded_public_key},
/*offsets=*/nullptr);
absl::optional<base::Value> json_object = base::JSONReader::Read(json_string);
ASSERT_TRUE(json_object) << "Incorrectly formatted JSON string.";
std::vector<PublicKey> keys =
aggregation_service::GetPublicKeys(json_object.value());
EXPECT_TRUE(keys.empty());
}
} // namespace content