blob: 50c7729ab70b9118a65d447fe5225296a4b14a0d [file] [log] [blame]
// Copyright 2024 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "chrome/browser/net/server_certificate_database.h"
#include "base/containers/span.h"
#include "base/containers/to_vector.h"
#include "base/files/file_path.h"
#include "base/files/file_util.h"
#include "base/files/scoped_temp_dir.h"
#include "base/strings/string_number_conversions.h"
#include "base/test/protobuf_matchers.h"
#include "base/test/task_environment.h"
#include "chrome/browser/net/server_certificate_database.pb.h"
#include "crypto/sha2.h"
#include "net/test/cert_builder.h"
#include "testing/gtest/include/gtest/gtest.h"
namespace net {
using ::base::test::EqualsProto;
using chrome_browser_server_certificate_database::CertificateTrust;
using ::testing::Matches;
using ::testing::UnorderedElementsAre;
class ServerCertificateDatabaseTest : public testing::Test {
public:
void SetUp() override {
ASSERT_TRUE(temp_dir_.CreateUniqueTempDir());
CreateDatabase();
}
void TearDown() override {
database_.reset();
ASSERT_TRUE(temp_dir_.Delete());
}
void CreateDatabase() {
database_ =
std::make_unique<ServerCertificateDatabase>(temp_dir_.GetPath());
}
protected:
base::test::TaskEnvironment task_environment_;
base::ScopedTempDir temp_dir_;
std::unique_ptr<ServerCertificateDatabase> database_;
};
MATCHER_P(CertInfoEquals, expected_value, "") {
return expected_value.get().sha256hash_hex == arg.sha256hash_hex &&
expected_value.get().der_cert == arg.der_cert &&
Matches(EqualsProto(expected_value.get().cert_metadata))(
arg.cert_metadata);
}
ServerCertificateDatabase::CertInformation MakeCertInfo(
const std::string der_cert,
CertificateTrust::CertificateTrustType trust_type) {
ServerCertificateDatabase::CertInformation cert_info;
cert_info.sha256hash_hex =
base::HexEncode(crypto::SHA256HashString(der_cert));
cert_info.cert_metadata.mutable_trust()->set_trust_type(trust_type);
cert_info.der_cert = base::ToVector(base::as_byte_span(der_cert));
return cert_info;
}
TEST_F(ServerCertificateDatabaseTest, StoreAndRetrieve) {
EXPECT_TRUE(database_->RetrieveAllCertificates().empty());
auto [leaf, intermediate, root] = CertBuilder::CreateSimpleChain3();
ServerCertificateDatabase::CertInformation root_cert_info = MakeCertInfo(
root->GetDER(), CertificateTrust::CERTIFICATE_TRUST_TYPE_TRUSTED);
ServerCertificateDatabase::CertInformation intermediate_cert_info =
MakeCertInfo(intermediate->GetDER(),
CertificateTrust::CERTIFICATE_TRUST_TYPE_UNSPECIFIED);
EXPECT_TRUE(database_->InsertOrUpdateCert(root_cert_info));
EXPECT_TRUE(database_->InsertOrUpdateCert(intermediate_cert_info));
EXPECT_THAT(
database_->RetrieveAllCertificates(),
UnorderedElementsAre(CertInfoEquals(std::ref(root_cert_info)),
CertInfoEquals(std::ref(intermediate_cert_info))));
// Reopen the database, and it should have the entries.
database_.reset();
CreateDatabase();
EXPECT_THAT(
database_->RetrieveAllCertificates(),
UnorderedElementsAre(CertInfoEquals(std::ref(intermediate_cert_info)),
CertInfoEquals(std::ref(root_cert_info))));
}
TEST_F(ServerCertificateDatabaseTest, Update) {
EXPECT_TRUE(database_->RetrieveAllCertificates().empty());
auto [leaf, intermediate, root] = CertBuilder::CreateSimpleChain3();
ServerCertificateDatabase::CertInformation root_cert_info = MakeCertInfo(
root->GetDER(), CertificateTrust::CERTIFICATE_TRUST_TYPE_TRUSTED);
ServerCertificateDatabase::CertInformation intermediate_cert_info =
MakeCertInfo(intermediate->GetDER(),
CertificateTrust::CERTIFICATE_TRUST_TYPE_UNSPECIFIED);
EXPECT_TRUE(database_->InsertOrUpdateCert(root_cert_info));
EXPECT_TRUE(database_->InsertOrUpdateCert(intermediate_cert_info));
EXPECT_THAT(
database_->RetrieveAllCertificates(),
UnorderedElementsAre(CertInfoEquals(std::ref(root_cert_info)),
CertInfoEquals(std::ref(intermediate_cert_info))));
root_cert_info.cert_metadata.mutable_trust()->set_trust_type(
CertificateTrust::CERTIFICATE_TRUST_TYPE_DISTRUSTED);
EXPECT_TRUE(database_->InsertOrUpdateCert(root_cert_info));
EXPECT_THAT(
database_->RetrieveAllCertificates(),
UnorderedElementsAre(CertInfoEquals(std::ref(root_cert_info)),
CertInfoEquals(std::ref(intermediate_cert_info))));
}
} // namespace net