1 /* Copyright (c) 2023, Google Inc.
2 *
3 * Permission to use, copy, modify, and/or distribute this software for any
4 * purpose with or without fee is hereby granted, provided that the above
5 * copyright notice and this permission notice appear in all copies.
6 *
7 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
8 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
9 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
10 * SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
11 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
12 * OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
13 * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */
14
15 #include <optional>
16 #include <string>
17 #include <string_view>
18
19 #include <openssl/pki/certificate.h>
20 #include <gmock/gmock.h>
21
22 #include "string_util.h"
23 #include "test_helpers.h"
24
TEST(CertificateTest,FromPEM)25 TEST(CertificateTest, FromPEM) {
26 std::string diagnostic;
27 std::unique_ptr<bssl::Certificate> cert(
28 bssl::Certificate::FromPEM("nonsense", &diagnostic));
29 EXPECT_FALSE(cert);
30
31 cert = bssl::Certificate::FromPEM(bssl::ReadTestFileToString(
32 "testdata/verify_unittest/self-issued.pem"), &diagnostic);
33 EXPECT_TRUE(cert);
34 }
35
TEST(CertificateTest,IsSelfIssued)36 TEST(CertificateTest, IsSelfIssued) {
37 std::string diagnostic;
38 const std::string leaf =
39 bssl::ReadTestFileToString("testdata/verify_unittest/google-leaf.der");
40 std::unique_ptr<bssl::Certificate> leaf_cert(
41 bssl::Certificate::FromDER(bssl::StringAsBytes(leaf), &diagnostic));
42 EXPECT_TRUE(leaf_cert);
43 EXPECT_FALSE(leaf_cert->IsSelfIssued());
44
45 const std::string self_issued =
46 bssl::ReadTestFileToString("testdata/verify_unittest/self-issued.pem");
47 std::unique_ptr<bssl::Certificate> self_issued_cert(
48 bssl::Certificate::FromPEM(self_issued, &diagnostic));
49 EXPECT_TRUE(self_issued_cert);
50 EXPECT_TRUE(self_issued_cert->IsSelfIssued());
51 }
52
TEST(CertificateTest,Validity)53 TEST(CertificateTest, Validity) {
54 std::string diagnostic;
55 const std::string leaf =
56 bssl::ReadTestFileToString("testdata/verify_unittest/google-leaf.der");
57 std::unique_ptr<bssl::Certificate> cert(
58 bssl::Certificate::FromDER(bssl::StringAsBytes(leaf), &diagnostic));
59 EXPECT_TRUE(cert);
60
61 bssl::Certificate::Validity validity = cert->GetValidity();
62 EXPECT_EQ(validity.not_before, 1498644466);
63 EXPECT_EQ(validity.not_after, 1505899620);
64 }
65
TEST(CertificateTest,SerialNumber)66 TEST(CertificateTest, SerialNumber) {
67 std::string diagnostic;
68 const std::string leaf =
69 bssl::ReadTestFileToString("testdata/verify_unittest/google-leaf.der");
70 std::unique_ptr<bssl::Certificate> cert(
71 bssl::Certificate::FromDER(bssl::StringAsBytes(leaf), &diagnostic));
72 EXPECT_TRUE(cert);
73
74 EXPECT_EQ(bssl::string_util::HexEncode(cert->GetSerialNumber()),
75 "0118F044A8F31892");
76 }
77