1*6777b538SAndroid Build Coastguard Worker // Copyright 2015 The Chromium Authors
2*6777b538SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be
3*6777b538SAndroid Build Coastguard Worker // found in the LICENSE file.
4*6777b538SAndroid Build Coastguard Worker
5*6777b538SAndroid Build Coastguard Worker #include "crypto/nss_key_util.h"
6*6777b538SAndroid Build Coastguard Worker
7*6777b538SAndroid Build Coastguard Worker #include <keyhi.h>
8*6777b538SAndroid Build Coastguard Worker #include <pk11pub.h>
9*6777b538SAndroid Build Coastguard Worker #include <stdint.h>
10*6777b538SAndroid Build Coastguard Worker
11*6777b538SAndroid Build Coastguard Worker #include <vector>
12*6777b538SAndroid Build Coastguard Worker
13*6777b538SAndroid Build Coastguard Worker #include "crypto/nss_util.h"
14*6777b538SAndroid Build Coastguard Worker #include "crypto/scoped_nss_types.h"
15*6777b538SAndroid Build Coastguard Worker #include "testing/gtest/include/gtest/gtest.h"
16*6777b538SAndroid Build Coastguard Worker
17*6777b538SAndroid Build Coastguard Worker namespace crypto {
18*6777b538SAndroid Build Coastguard Worker
19*6777b538SAndroid Build Coastguard Worker class NSSKeyUtilTest : public testing::Test {
20*6777b538SAndroid Build Coastguard Worker public:
SetUp()21*6777b538SAndroid Build Coastguard Worker void SetUp() override {
22*6777b538SAndroid Build Coastguard Worker EnsureNSSInit();
23*6777b538SAndroid Build Coastguard Worker
24*6777b538SAndroid Build Coastguard Worker internal_slot_.reset(PK11_GetInternalSlot());
25*6777b538SAndroid Build Coastguard Worker ASSERT_TRUE(internal_slot_);
26*6777b538SAndroid Build Coastguard Worker }
27*6777b538SAndroid Build Coastguard Worker
internal_slot()28*6777b538SAndroid Build Coastguard Worker PK11SlotInfo* internal_slot() { return internal_slot_.get(); }
29*6777b538SAndroid Build Coastguard Worker
30*6777b538SAndroid Build Coastguard Worker private:
31*6777b538SAndroid Build Coastguard Worker ScopedPK11Slot internal_slot_;
32*6777b538SAndroid Build Coastguard Worker };
33*6777b538SAndroid Build Coastguard Worker
TEST_F(NSSKeyUtilTest,GenerateRSAKeyPairNSS)34*6777b538SAndroid Build Coastguard Worker TEST_F(NSSKeyUtilTest, GenerateRSAKeyPairNSS) {
35*6777b538SAndroid Build Coastguard Worker const int kKeySizeBits = 1024;
36*6777b538SAndroid Build Coastguard Worker
37*6777b538SAndroid Build Coastguard Worker ScopedSECKEYPublicKey public_key;
38*6777b538SAndroid Build Coastguard Worker ScopedSECKEYPrivateKey private_key;
39*6777b538SAndroid Build Coastguard Worker ASSERT_TRUE(GenerateRSAKeyPairNSS(internal_slot(), kKeySizeBits,
40*6777b538SAndroid Build Coastguard Worker false /* not permanent */, &public_key,
41*6777b538SAndroid Build Coastguard Worker &private_key));
42*6777b538SAndroid Build Coastguard Worker
43*6777b538SAndroid Build Coastguard Worker EXPECT_EQ(rsaKey, SECKEY_GetPublicKeyType(public_key.get()));
44*6777b538SAndroid Build Coastguard Worker EXPECT_EQ(rsaKey, SECKEY_GetPrivateKeyType(private_key.get()));
45*6777b538SAndroid Build Coastguard Worker EXPECT_EQ((kKeySizeBits + 7) / 8,
46*6777b538SAndroid Build Coastguard Worker PK11_GetPrivateModulusLen(private_key.get()));
47*6777b538SAndroid Build Coastguard Worker }
48*6777b538SAndroid Build Coastguard Worker
TEST_F(NSSKeyUtilTest,FindNSSKeyFromPublicKeyInfo)49*6777b538SAndroid Build Coastguard Worker TEST_F(NSSKeyUtilTest, FindNSSKeyFromPublicKeyInfo) {
50*6777b538SAndroid Build Coastguard Worker // Create an NSS keypair, which will put the keys in the user's NSSDB.
51*6777b538SAndroid Build Coastguard Worker ScopedSECKEYPublicKey public_key;
52*6777b538SAndroid Build Coastguard Worker ScopedSECKEYPrivateKey private_key;
53*6777b538SAndroid Build Coastguard Worker ASSERT_TRUE(GenerateRSAKeyPairNSS(internal_slot(), 512,
54*6777b538SAndroid Build Coastguard Worker false /* not permanent */, &public_key,
55*6777b538SAndroid Build Coastguard Worker &private_key));
56*6777b538SAndroid Build Coastguard Worker
57*6777b538SAndroid Build Coastguard Worker ScopedSECItem item(SECKEY_EncodeDERSubjectPublicKeyInfo(public_key.get()));
58*6777b538SAndroid Build Coastguard Worker ASSERT_TRUE(item);
59*6777b538SAndroid Build Coastguard Worker std::vector<uint8_t> public_key_der(item->data, item->data + item->len);
60*6777b538SAndroid Build Coastguard Worker
61*6777b538SAndroid Build Coastguard Worker ScopedSECKEYPrivateKey private_key2 =
62*6777b538SAndroid Build Coastguard Worker FindNSSKeyFromPublicKeyInfo(public_key_der);
63*6777b538SAndroid Build Coastguard Worker ASSERT_TRUE(private_key2);
64*6777b538SAndroid Build Coastguard Worker EXPECT_EQ(private_key->pkcs11ID, private_key2->pkcs11ID);
65*6777b538SAndroid Build Coastguard Worker }
66*6777b538SAndroid Build Coastguard Worker
TEST_F(NSSKeyUtilTest,FailedFindNSSKeyFromPublicKeyInfo)67*6777b538SAndroid Build Coastguard Worker TEST_F(NSSKeyUtilTest, FailedFindNSSKeyFromPublicKeyInfo) {
68*6777b538SAndroid Build Coastguard Worker // Create an NSS keypair, which will put the keys in the user's NSSDB.
69*6777b538SAndroid Build Coastguard Worker ScopedSECKEYPublicKey public_key;
70*6777b538SAndroid Build Coastguard Worker ScopedSECKEYPrivateKey private_key;
71*6777b538SAndroid Build Coastguard Worker ASSERT_TRUE(GenerateRSAKeyPairNSS(internal_slot(), 512,
72*6777b538SAndroid Build Coastguard Worker false /* not permanent */, &public_key,
73*6777b538SAndroid Build Coastguard Worker &private_key));
74*6777b538SAndroid Build Coastguard Worker
75*6777b538SAndroid Build Coastguard Worker ScopedSECItem item(SECKEY_EncodeDERSubjectPublicKeyInfo(public_key.get()));
76*6777b538SAndroid Build Coastguard Worker ASSERT_TRUE(item);
77*6777b538SAndroid Build Coastguard Worker std::vector<uint8_t> public_key_der(item->data, item->data + item->len);
78*6777b538SAndroid Build Coastguard Worker
79*6777b538SAndroid Build Coastguard Worker // Remove the keys from the DB, and make sure we can't find them again.
80*6777b538SAndroid Build Coastguard Worker PK11_DestroyTokenObject(private_key->pkcs11Slot, private_key->pkcs11ID);
81*6777b538SAndroid Build Coastguard Worker PK11_DestroyTokenObject(public_key->pkcs11Slot, public_key->pkcs11ID);
82*6777b538SAndroid Build Coastguard Worker
83*6777b538SAndroid Build Coastguard Worker EXPECT_FALSE(FindNSSKeyFromPublicKeyInfo(public_key_der));
84*6777b538SAndroid Build Coastguard Worker }
85*6777b538SAndroid Build Coastguard Worker
86*6777b538SAndroid Build Coastguard Worker } // namespace crypto
87