blob: 8a9cca74cb14f24f58f7373056634b8bff6edb82 [file] [log] [blame]
[email protected]eaa60482011-11-09 05:08:511// Copyright (c) 2011 The Chromium Authors. All rights reserved.
2// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#include "crypto/ec_private_key.h"
6
avidd373b8b2015-12-21 21:34:437#include <stdint.h>
8
thakisd1a18472016-04-08 22:30:419#include <memory>
[email protected]eaa60482011-11-09 05:08:5110#include <vector>
11
Avi Drissman34f6b422018-12-25 20:29:3912#include "base/stl_util.h"
[email protected]eaa60482011-11-09 05:08:5113#include "testing/gtest/include/gtest/gtest.h"
14
davidben212cdf62016-06-07 17:11:0915namespace {
[email protected]eaa60482011-11-09 05:08:5116
davidben212cdf62016-06-07 17:11:0917void ExpectKeysEqual(const crypto::ECPrivateKey* keypair1,
18 const crypto::ECPrivateKey* keypair2) {
avidd373b8b2015-12-21 21:34:4319 std::vector<uint8_t> privkey1;
20 std::vector<uint8_t> privkey2;
davidben212cdf62016-06-07 17:11:0921 EXPECT_TRUE(keypair1->ExportPrivateKey(&privkey1));
22 EXPECT_TRUE(keypair2->ExportPrivateKey(&privkey2));
23 EXPECT_EQ(privkey1, privkey2);
[email protected]ac30ed0e2014-06-24 04:12:3424
avidd373b8b2015-12-21 21:34:4325 std::vector<uint8_t> pubkey1;
26 std::vector<uint8_t> pubkey2;
[email protected]ac30ed0e2014-06-24 04:12:3427 EXPECT_TRUE(keypair1->ExportPublicKey(&pubkey1));
28 EXPECT_TRUE(keypair2->ExportPublicKey(&pubkey2));
29 EXPECT_EQ(pubkey1, pubkey2);
30
31 std::string raw_pubkey1;
32 std::string raw_pubkey2;
33 EXPECT_TRUE(keypair1->ExportRawPublicKey(&raw_pubkey1));
34 EXPECT_TRUE(keypair2->ExportRawPublicKey(&raw_pubkey2));
35 EXPECT_EQ(raw_pubkey1, raw_pubkey2);
36}
[email protected]ac30ed0e2014-06-24 04:12:3437
davidben212cdf62016-06-07 17:11:0938} // namespace
39
40// Generate random private keys. Export, then re-import in several ways. We
41// should get back the same exact public key, and the private key should have
42// the same value and elliptic curve params.
43TEST(ECPrivateKeyUnitTest, InitRandomTest) {
davidben212cdf62016-06-07 17:11:0944 std::unique_ptr<crypto::ECPrivateKey> keypair(crypto::ECPrivateKey::Create());
rsleeviffe5a132016-06-28 01:51:5245 ASSERT_TRUE(keypair);
davidben212cdf62016-06-07 17:11:0946
47 // Re-import as a PrivateKeyInfo.
48 std::vector<uint8_t> privkey;
49 EXPECT_TRUE(keypair->ExportPrivateKey(&privkey));
50 std::unique_ptr<crypto::ECPrivateKey> keypair_copy =
51 crypto::ECPrivateKey::CreateFromPrivateKeyInfo(privkey);
52 ASSERT_TRUE(keypair_copy);
53 ExpectKeysEqual(keypair.get(), keypair_copy.get());
54
55 // Re-import as an EncryptedPrivateKeyInfo with kPassword1.
56 std::vector<uint8_t> encrypted_privkey;
davidben1c02c94c2017-01-04 13:54:3257 EXPECT_TRUE(keypair->ExportEncryptedPrivateKey(&encrypted_privkey));
rsleeviffe5a132016-06-28 01:51:5258 keypair_copy = crypto::ECPrivateKey::CreateFromEncryptedPrivateKeyInfo(
David Benjaminb86b0a082017-09-21 16:55:3659 encrypted_privkey);
davidben212cdf62016-06-07 17:11:0960 ASSERT_TRUE(keypair_copy);
61 ExpectKeysEqual(keypair.get(), keypair_copy.get());
62}
63
64TEST(ECPrivateKeyUnitTest, Copy) {
65 std::unique_ptr<crypto::ECPrivateKey> keypair1(
66 crypto::ECPrivateKey::Create());
67 std::unique_ptr<crypto::ECPrivateKey> keypair2(keypair1->Copy());
rsleeviffe5a132016-06-28 01:51:5268 ASSERT_TRUE(keypair1);
69 ASSERT_TRUE(keypair2);
davidben212cdf62016-06-07 17:11:0970
71 ExpectKeysEqual(keypair1.get(), keypair2.get());
72}
73
74TEST(ECPrivateKeyUnitTest, CreateFromPrivateKeyInfo) {
75 static const uint8_t kPrivateKeyInfo[] = {
76 0x30, 0x81, 0x87, 0x02, 0x01, 0x00, 0x30, 0x13, 0x06, 0x07, 0x2a, 0x86,
77 0x48, 0xce, 0x3d, 0x02, 0x01, 0x06, 0x08, 0x2a, 0x86, 0x48, 0xce, 0x3d,
78 0x03, 0x01, 0x07, 0x04, 0x6d, 0x30, 0x6b, 0x02, 0x01, 0x01, 0x04, 0x20,
79 0x07, 0x0f, 0x08, 0x72, 0x7a, 0xd4, 0xa0, 0x4a, 0x9c, 0xdd, 0x59, 0xc9,
80 0x4d, 0x89, 0x68, 0x77, 0x08, 0xb5, 0x6f, 0xc9, 0x5d, 0x30, 0x77, 0x0e,
81 0xe8, 0xd1, 0xc9, 0xce, 0x0a, 0x8b, 0xb4, 0x6a, 0xa1, 0x44, 0x03, 0x42,
82 0x00, 0x04, 0xe6, 0x2b, 0x69, 0xe2, 0xbf, 0x65, 0x9f, 0x97, 0xbe, 0x2f,
83 0x1e, 0x0d, 0x94, 0x8a, 0x4c, 0xd5, 0x97, 0x6b, 0xb7, 0xa9, 0x1e, 0x0d,
84 0x46, 0xfb, 0xdd, 0xa9, 0xa9, 0x1e, 0x9d, 0xdc, 0xba, 0x5a, 0x01, 0xe7,
85 0xd6, 0x97, 0xa8, 0x0a, 0x18, 0xf9, 0xc3, 0xc4, 0xa3, 0x1e, 0x56, 0xe2,
86 0x7c, 0x83, 0x48, 0xdb, 0x16, 0x1a, 0x1c, 0xf5, 0x1d, 0x7e, 0xf1, 0x94,
87 0x2d, 0x4b, 0xcf, 0x72, 0x22, 0xc1,
88 };
89 static const uint8_t kSubjectPublicKeyInfo[] = {
90 0x30, 0x59, 0x30, 0x13, 0x06, 0x07, 0x2a, 0x86, 0x48, 0xce, 0x3d, 0x02,
91 0x01, 0x06, 0x08, 0x2a, 0x86, 0x48, 0xce, 0x3d, 0x03, 0x01, 0x07, 0x03,
92 0x42, 0x00, 0x04, 0xe6, 0x2b, 0x69, 0xe2, 0xbf, 0x65, 0x9f, 0x97, 0xbe,
93 0x2f, 0x1e, 0x0d, 0x94, 0x8a, 0x4c, 0xd5, 0x97, 0x6b, 0xb7, 0xa9, 0x1e,
94 0x0d, 0x46, 0xfb, 0xdd, 0xa9, 0xa9, 0x1e, 0x9d, 0xdc, 0xba, 0x5a, 0x01,
95 0xe7, 0xd6, 0x97, 0xa8, 0x0a, 0x18, 0xf9, 0xc3, 0xc4, 0xa3, 0x1e, 0x56,
96 0xe2, 0x7c, 0x83, 0x48, 0xdb, 0x16, 0x1a, 0x1c, 0xf5, 0x1d, 0x7e, 0xf1,
97 0x94, 0x2d, 0x4b, 0xcf, 0x72, 0x22, 0xc1,
98 };
99 static const uint8_t kRawPublicKey[] = {
100 0xe6, 0x2b, 0x69, 0xe2, 0xbf, 0x65, 0x9f, 0x97, 0xbe, 0x2f, 0x1e,
101 0x0d, 0x94, 0x8a, 0x4c, 0xd5, 0x97, 0x6b, 0xb7, 0xa9, 0x1e, 0x0d,
102 0x46, 0xfb, 0xdd, 0xa9, 0xa9, 0x1e, 0x9d, 0xdc, 0xba, 0x5a, 0x01,
103 0xe7, 0xd6, 0x97, 0xa8, 0x0a, 0x18, 0xf9, 0xc3, 0xc4, 0xa3, 0x1e,
104 0x56, 0xe2, 0x7c, 0x83, 0x48, 0xdb, 0x16, 0x1a, 0x1c, 0xf5, 0x1d,
105 0x7e, 0xf1, 0x94, 0x2d, 0x4b, 0xcf, 0x72, 0x22, 0xc1,
106 };
107
108 std::unique_ptr<crypto::ECPrivateKey> key =
109 crypto::ECPrivateKey::CreateFromPrivateKeyInfo(std::vector<uint8_t>(
110 std::begin(kPrivateKeyInfo), std::end(kPrivateKeyInfo)));
111 ASSERT_TRUE(key);
112
113 std::vector<uint8_t> public_key;
114 ASSERT_TRUE(key->ExportPublicKey(&public_key));
115 EXPECT_EQ(std::vector<uint8_t>(std::begin(kSubjectPublicKeyInfo),
116 std::end(kSubjectPublicKeyInfo)),
117 public_key);
118
119 std::string raw_public_key;
120 ASSERT_TRUE(key->ExportRawPublicKey(&raw_public_key));
121 EXPECT_EQ(std::string(reinterpret_cast<const char*>(kRawPublicKey),
122 sizeof(kRawPublicKey)),
123 raw_public_key);
124}
125
Alex Chau2a2e94672019-10-14 20:14:05126TEST(ECPrivateKeyUnitTest, DeriveFromSecret) {
127 static const uint8_t kSecret[] = {
128 0x90, 0x48, 0x0a, 0x51, 0x77, 0xa3, 0x72, 0xfb, 0xba, 0x0f, 0x08,
129 0x5e, 0xc5, 0x6f, 0x8f, 0x6d, 0x1c, 0xaf, 0xa9, 0x8a, 0xdf, 0xa9,
130 0x7c, 0x38, 0x70, 0x47, 0xb9, 0x72, 0xcc, 0x5c, 0xaa, 0xc2,
131 };
132
133 static const uint8_t kPrivateKeyInfo[] = {
134 0x30, 0x81, 0x87, 0x02, 0x01, 0x00, 0x30, 0x13, 0x06, 0x07, 0x2a, 0x86,
135 0x48, 0xce, 0x3d, 0x02, 0x01, 0x06, 0x08, 0x2a, 0x86, 0x48, 0xce, 0x3d,
136 0x03, 0x01, 0x07, 0x04, 0x6d, 0x30, 0x6b, 0x02, 0x01, 0x01, 0x04, 0x20,
137 0x0e, 0x87, 0xc8, 0x4d, 0x92, 0x14, 0x52, 0x93, 0x96, 0xad, 0x63, 0x9a,
138 0x6a, 0xa7, 0xeb, 0x56, 0x5c, 0xaf, 0xab, 0x69, 0x06, 0xd4, 0x37, 0xf8,
139 0x7d, 0xd7, 0x04, 0xa9, 0xec, 0x6e, 0x2e, 0x96, 0xa1, 0x44, 0x03, 0x42,
140 0x00, 0x04, 0xe2, 0xf5, 0x86, 0x4a, 0xf6, 0xe0, 0x7d, 0x19, 0x94, 0x2d,
141 0x54, 0x16, 0x58, 0x98, 0x62, 0x78, 0xf2, 0x8f, 0x30, 0x77, 0x93, 0x7d,
142 0x2c, 0x17, 0x29, 0xe5, 0x50, 0x42, 0xed, 0x8d, 0x6c, 0x31, 0x34, 0x16,
143 0x20, 0x4f, 0xcc, 0x50, 0x09, 0xaf, 0x8d, 0x56, 0x56, 0x73, 0xe3, 0xb9,
144 0x5a, 0x15, 0xbf, 0x73, 0x25, 0x91, 0xa0, 0xaf, 0x8f, 0x64, 0x19, 0xf4,
145 0x17, 0x8e, 0x7a, 0x05, 0x76, 0x23,
146 };
147
148 static const uint8_t kSubjectPublicKeyInfo[] = {
149 0x30, 0x59, 0x30, 0x13, 0x06, 0x07, 0x2a, 0x86, 0x48, 0xce, 0x3d, 0x02,
150 0x01, 0x06, 0x08, 0x2a, 0x86, 0x48, 0xce, 0x3d, 0x03, 0x01, 0x07, 0x03,
151 0x42, 0x00, 0x04, 0xe2, 0xf5, 0x86, 0x4a, 0xf6, 0xe0, 0x7d, 0x19, 0x94,
152 0x2d, 0x54, 0x16, 0x58, 0x98, 0x62, 0x78, 0xf2, 0x8f, 0x30, 0x77, 0x93,
153 0x7d, 0x2c, 0x17, 0x29, 0xe5, 0x50, 0x42, 0xed, 0x8d, 0x6c, 0x31, 0x34,
154 0x16, 0x20, 0x4f, 0xcc, 0x50, 0x09, 0xaf, 0x8d, 0x56, 0x56, 0x73, 0xe3,
155 0xb9, 0x5a, 0x15, 0xbf, 0x73, 0x25, 0x91, 0xa0, 0xaf, 0x8f, 0x64, 0x19,
156 0xf4, 0x17, 0x8e, 0x7a, 0x05, 0x76, 0x23,
157 };
158 static const uint8_t kRawPublicKey[] = {
159 0xe2, 0xf5, 0x86, 0x4a, 0xf6, 0xe0, 0x7d, 0x19, 0x94, 0x2d, 0x54,
160 0x16, 0x58, 0x98, 0x62, 0x78, 0xf2, 0x8f, 0x30, 0x77, 0x93, 0x7d,
161 0x2c, 0x17, 0x29, 0xe5, 0x50, 0x42, 0xed, 0x8d, 0x6c, 0x31, 0x34,
162 0x16, 0x20, 0x4f, 0xcc, 0x50, 0x09, 0xaf, 0x8d, 0x56, 0x56, 0x73,
163 0xe3, 0xb9, 0x5a, 0x15, 0xbf, 0x73, 0x25, 0x91, 0xa0, 0xaf, 0x8f,
164 0x64, 0x19, 0xf4, 0x17, 0x8e, 0x7a, 0x05, 0x76, 0x23,
165 };
166
167 std::unique_ptr<crypto::ECPrivateKey> key(
168 crypto::ECPrivateKey::DeriveFromSecret(kSecret));
169 ASSERT_TRUE(key);
170
171 std::vector<uint8_t> privkey;
172 EXPECT_TRUE(key->ExportPrivateKey(&privkey));
173 EXPECT_EQ(std::vector<uint8_t>(std::begin(kPrivateKeyInfo),
174 std::end(kPrivateKeyInfo)),
175 privkey);
176
177 std::vector<uint8_t> public_key;
178 ASSERT_TRUE(key->ExportPublicKey(&public_key));
179 EXPECT_EQ(std::vector<uint8_t>(std::begin(kSubjectPublicKeyInfo),
180 std::end(kSubjectPublicKeyInfo)),
181 public_key);
182
183 std::string raw_public_key;
184 ASSERT_TRUE(key->ExportRawPublicKey(&raw_public_key));
185 EXPECT_EQ(std::string(reinterpret_cast<const char*>(kRawPublicKey),
186 sizeof(kRawPublicKey)),
187 raw_public_key);
188}
189
davidben212cdf62016-06-07 17:11:09190TEST(ECPrivateKeyUnitTest, RSAPrivateKeyInfo) {
191 static const uint8_t kPrivateKeyInfo[] = {
192 0x30, 0x82, 0x02, 0x78, 0x02, 0x01, 0x00, 0x30, 0x0d, 0x06, 0x09, 0x2a,
193 0x86, 0x48, 0x86, 0xf7, 0x0d, 0x01, 0x01, 0x01, 0x05, 0x00, 0x04, 0x82,
194 0x02, 0x62, 0x30, 0x82, 0x02, 0x5e, 0x02, 0x01, 0x00, 0x02, 0x81, 0x81,
195 0x00, 0xb8, 0x7f, 0x2b, 0x20, 0xdc, 0x7c, 0x9b, 0x0c, 0xdc, 0x51, 0x61,
196 0x99, 0x0d, 0x36, 0x0f, 0xd4, 0x66, 0x88, 0x08, 0x55, 0x84, 0xd5, 0x3a,
197 0xbf, 0x2b, 0xa4, 0x64, 0x85, 0x7b, 0x0c, 0x04, 0x13, 0x3f, 0x8d, 0xf4,
198 0xbc, 0x38, 0x0d, 0x49, 0xfe, 0x6b, 0xc4, 0x5a, 0xb0, 0x40, 0x53, 0x3a,
199 0xd7, 0x66, 0x09, 0x0f, 0x9e, 0x36, 0x74, 0x30, 0xda, 0x8a, 0x31, 0x4f,
200 0x1f, 0x14, 0x50, 0xd7, 0xc7, 0x20, 0x94, 0x17, 0xde, 0x4e, 0xb9, 0x57,
201 0x5e, 0x7e, 0x0a, 0xe5, 0xb2, 0x65, 0x7a, 0x89, 0x4e, 0xb6, 0x47, 0xff,
202 0x1c, 0xbd, 0xb7, 0x38, 0x13, 0xaf, 0x47, 0x85, 0x84, 0x32, 0x33, 0xf3,
203 0x17, 0x49, 0xbf, 0xe9, 0x96, 0xd0, 0xd6, 0x14, 0x6f, 0x13, 0x8d, 0xc5,
204 0xfc, 0x2c, 0x72, 0xba, 0xac, 0xea, 0x7e, 0x18, 0x53, 0x56, 0xa6, 0x83,
205 0xa2, 0xce, 0x93, 0x93, 0xe7, 0x1f, 0x0f, 0xe6, 0x0f, 0x02, 0x03, 0x01,
206 0x00, 0x01, 0x02, 0x81, 0x80, 0x03, 0x61, 0x89, 0x37, 0xcb, 0xf2, 0x98,
207 0xa0, 0xce, 0xb4, 0xcb, 0x16, 0x13, 0xf0, 0xe6, 0xaf, 0x5c, 0xc5, 0xa7,
208 0x69, 0x71, 0xca, 0xba, 0x8d, 0xe0, 0x4d, 0xdd, 0xed, 0xb8, 0x48, 0x8b,
209 0x16, 0x93, 0x36, 0x95, 0xc2, 0x91, 0x40, 0x65, 0x17, 0xbd, 0x7f, 0xd6,
210 0xad, 0x9e, 0x30, 0x28, 0x46, 0xe4, 0x3e, 0xcc, 0x43, 0x78, 0xf9, 0xfe,
211 0x1f, 0x33, 0x23, 0x1e, 0x31, 0x12, 0x9d, 0x3c, 0xa7, 0x08, 0x82, 0x7b,
212 0x7d, 0x25, 0x4e, 0x5e, 0x19, 0xa8, 0x9b, 0xed, 0x86, 0xb2, 0xcb, 0x3c,
213 0xfe, 0x4e, 0xa1, 0xfa, 0x62, 0x87, 0x3a, 0x17, 0xf7, 0x60, 0xec, 0x38,
214 0x29, 0xe8, 0x4f, 0x34, 0x9f, 0x76, 0x9d, 0xee, 0xa3, 0xf6, 0x85, 0x6b,
215 0x84, 0x43, 0xc9, 0x1e, 0x01, 0xff, 0xfd, 0xd0, 0x29, 0x4c, 0xfa, 0x8e,
216 0x57, 0x0c, 0xc0, 0x71, 0xa5, 0xbb, 0x88, 0x46, 0x29, 0x5c, 0xc0, 0x4f,
217 0x01, 0x02, 0x41, 0x00, 0xf5, 0x83, 0xa4, 0x64, 0x4a, 0xf2, 0xdd, 0x8c,
218 0x2c, 0xed, 0xa8, 0xd5, 0x60, 0x5a, 0xe4, 0xc7, 0xcc, 0x61, 0xcd, 0x38,
219 0x42, 0x20, 0xd3, 0x82, 0x18, 0xf2, 0x35, 0x00, 0x72, 0x2d, 0xf7, 0x89,
220 0x80, 0x67, 0xb5, 0x93, 0x05, 0x5f, 0xdd, 0x42, 0xba, 0x16, 0x1a, 0xea,
221 0x15, 0xc6, 0xf0, 0xb8, 0x8c, 0xbc, 0xbf, 0x54, 0x9e, 0xf1, 0xc1, 0xb2,
222 0xb3, 0x8b, 0xb6, 0x26, 0x02, 0x30, 0xc4, 0x81, 0x02, 0x41, 0x00, 0xc0,
223 0x60, 0x62, 0x80, 0xe1, 0x22, 0x78, 0xf6, 0x9d, 0x83, 0x18, 0xeb, 0x72,
224 0x45, 0xd7, 0xc8, 0x01, 0x7f, 0xa9, 0xca, 0x8f, 0x7d, 0xd6, 0xb8, 0x31,
225 0x2b, 0x84, 0x7f, 0x62, 0xd9, 0xa9, 0x22, 0x17, 0x7d, 0x06, 0x35, 0x6c,
226 0xf3, 0xc1, 0x94, 0x17, 0x85, 0x5a, 0xaf, 0x9c, 0x5c, 0x09, 0x3c, 0xcf,
227 0x2f, 0x44, 0x9d, 0xb6, 0x52, 0x68, 0x5f, 0xf9, 0x59, 0xc8, 0x84, 0x2b,
228 0x39, 0x22, 0x8f, 0x02, 0x41, 0x00, 0xb2, 0x04, 0xe2, 0x0e, 0x56, 0xca,
229 0x03, 0x1a, 0xc0, 0xf9, 0x12, 0x92, 0xa5, 0x6b, 0x42, 0xb8, 0x1c, 0xda,
230 0x4d, 0x93, 0x9d, 0x5f, 0x6f, 0xfd, 0xc5, 0x58, 0xda, 0x55, 0x98, 0x74,
231 0xfc, 0x28, 0x17, 0x93, 0x1b, 0x75, 0x9f, 0x50, 0x03, 0x7f, 0x7e, 0xae,
232 0xc8, 0x95, 0x33, 0x75, 0x2c, 0xd6, 0xa4, 0x35, 0xb8, 0x06, 0x03, 0xba,
233 0x08, 0x59, 0x2b, 0x17, 0x02, 0xdc, 0x4c, 0x7a, 0x50, 0x01, 0x02, 0x41,
234 0x00, 0x9d, 0xdb, 0x39, 0x59, 0x09, 0xe4, 0x30, 0xa0, 0x24, 0xf5, 0xdb,
235 0x2f, 0xf0, 0x2f, 0xf1, 0x75, 0x74, 0x0d, 0x5e, 0xb5, 0x11, 0x73, 0xb0,
236 0x0a, 0xaa, 0x86, 0x4c, 0x0d, 0xff, 0x7e, 0x1d, 0xb4, 0x14, 0xd4, 0x09,
237 0x91, 0x33, 0x5a, 0xfd, 0xa0, 0x58, 0x80, 0x9b, 0xbe, 0x78, 0x2e, 0x69,
238 0x82, 0x15, 0x7c, 0x72, 0xf0, 0x7b, 0x18, 0x39, 0xff, 0x6e, 0xeb, 0xc6,
239 0x86, 0xf5, 0xb4, 0xc7, 0x6f, 0x02, 0x41, 0x00, 0x8d, 0x1a, 0x37, 0x0f,
240 0x76, 0xc4, 0x82, 0xfa, 0x5c, 0xc3, 0x79, 0x35, 0x3e, 0x70, 0x8a, 0xbf,
241 0x27, 0x49, 0xb0, 0x99, 0x63, 0xcb, 0x77, 0x5f, 0xa8, 0x82, 0x65, 0xf6,
242 0x03, 0x52, 0x51, 0xf1, 0xae, 0x2e, 0x05, 0xb3, 0xc6, 0xa4, 0x92, 0xd1,
243 0xce, 0x6c, 0x72, 0xfb, 0x21, 0xb3, 0x02, 0x87, 0xe4, 0xfd, 0x61, 0xca,
244 0x00, 0x42, 0x19, 0xf0, 0xda, 0x5a, 0x53, 0xe3, 0xb1, 0xc5, 0x15, 0xf3,
245 };
246
247 std::unique_ptr<crypto::ECPrivateKey> key =
248 crypto::ECPrivateKey::CreateFromPrivateKeyInfo(std::vector<uint8_t>(
249 std::begin(kPrivateKeyInfo), std::end(kPrivateKeyInfo)));
250 EXPECT_FALSE(key);
251}
252
[email protected]cdddc0f92014-03-22 02:42:47253TEST(ECPrivateKeyUnitTest, LoadNSSKeyTest) {
davidben7dad2a32016-03-01 23:47:47254 static const uint8_t kNSSKey[] = {
[email protected]cdddc0f92014-03-22 02:42:47255 0x30, 0x81, 0xb8, 0x30, 0x23, 0x06, 0x0a, 0x2a, 0x86, 0x48, 0x86, 0xf7,
256 0x0d, 0x01, 0x0c, 0x01, 0x03, 0x30, 0x15, 0x04, 0x10, 0x3f, 0xac, 0xe9,
257 0x38, 0xdb, 0x40, 0x6b, 0x26, 0x89, 0x09, 0x73, 0x18, 0x8d, 0x7f, 0x1c,
258 0x82, 0x02, 0x01, 0x01, 0x04, 0x81, 0x90, 0x5e, 0x5e, 0x11, 0xef, 0xbb,
259 0x7c, 0x4d, 0xec, 0xc0, 0xdc, 0xc7, 0x23, 0xd2, 0xc4, 0x77, 0xbc, 0xf4,
260 0x5d, 0x59, 0x4c, 0x07, 0xc2, 0x8a, 0x26, 0xfa, 0x25, 0x1c, 0xaa, 0x42,
261 0xed, 0xd0, 0xed, 0xbb, 0x5c, 0xe9, 0x13, 0x07, 0xaa, 0xdd, 0x52, 0x3c,
262 0x65, 0x25, 0xbf, 0x94, 0x02, 0xaf, 0xd6, 0x97, 0xe9, 0x33, 0x00, 0x76,
263 0x64, 0x4a, 0x73, 0xab, 0xfb, 0x99, 0x6e, 0x83, 0x12, 0x05, 0x86, 0x72,
264 0x6c, 0xd5, 0xa4, 0xcf, 0xb1, 0xd5, 0x4d, 0x54, 0x87, 0x8b, 0x4b, 0x95,
265 0x1d, 0xcd, 0xf3, 0xfe, 0xa8, 0xda, 0xe0, 0xb6, 0x72, 0x13, 0x3f, 0x2e,
266 0x66, 0xe0, 0xb9, 0x2e, 0xfa, 0x69, 0x40, 0xbe, 0xd7, 0x67, 0x6e, 0x53,
267 0x2b, 0x3f, 0x53, 0xe5, 0x39, 0x54, 0x77, 0xe1, 0x1d, 0xe6, 0x81, 0x92,
268 0x58, 0x82, 0x14, 0xfb, 0x47, 0x85, 0x3c, 0xc3, 0xdf, 0xdd, 0xcc, 0x79,
269 0x9f, 0x41, 0x83, 0x72, 0xf2, 0x0a, 0xe9, 0xe1, 0x2c, 0x12, 0xb0, 0xb0,
davidben7dad2a32016-03-01 23:47:47270 0x0a, 0xb2, 0x1d, 0xca, 0x15, 0xb2, 0xca,
271 };
[email protected]cdddc0f92014-03-22 02:42:47272
thakisd1a18472016-04-08 22:30:41273 std::unique_ptr<crypto::ECPrivateKey> keypair_nss(
[email protected]cdddc0f92014-03-22 02:42:47274 crypto::ECPrivateKey::CreateFromEncryptedPrivateKeyInfo(
David Benjaminb86b0a082017-09-21 16:55:36275 std::vector<uint8_t>(std::begin(kNSSKey), std::end(kNSSKey))));
[email protected]cdddc0f92014-03-22 02:42:47276
rsleeviffe5a132016-06-28 01:51:52277 EXPECT_TRUE(keypair_nss);
[email protected]cdddc0f92014-03-22 02:42:47278}
279
[email protected]cdddc0f92014-03-22 02:42:47280TEST(ECPrivateKeyUnitTest, LoadOpenSSLKeyTest) {
davidben7dad2a32016-03-01 23:47:47281 static const uint8_t kOpenSSLKey[] = {
[email protected]dc06f752014-08-06 23:11:09282 0x30, 0x81, 0xb0, 0x30, 0x1b, 0x06, 0x0a, 0x2a, 0x86, 0x48, 0x86, 0xf7,
283 0x0d, 0x01, 0x0c, 0x01, 0x03, 0x30, 0x0d, 0x04, 0x08, 0xb2, 0xfe, 0x68,
284 0xc2, 0xea, 0x0f, 0x10, 0x9c, 0x02, 0x01, 0x01, 0x04, 0x81, 0x90, 0xe2,
285 0xf6, 0x1c, 0xca, 0xad, 0x64, 0x30, 0xbf, 0x88, 0x04, 0x35, 0xe5, 0x0f,
286 0x11, 0x49, 0x06, 0x01, 0x14, 0x33, 0x80, 0xa2, 0x78, 0x44, 0x5b, 0xaa,
287 0x0d, 0xd7, 0x00, 0x36, 0x9d, 0x91, 0x97, 0x37, 0x20, 0x7b, 0x27, 0xc1,
288 0xa0, 0xa2, 0x73, 0x06, 0x15, 0xdf, 0xc8, 0x13, 0x9b, 0xc9, 0x8c, 0x9c,
289 0xce, 0x00, 0xd0, 0xc8, 0x42, 0xc1, 0xda, 0x2b, 0x07, 0x2b, 0x12, 0xa3,
290 0xce, 0x10, 0x39, 0x7a, 0xf1, 0x55, 0x69, 0x8d, 0xa5, 0xc4, 0x2a, 0x00,
291 0x0d, 0x94, 0xc6, 0xde, 0x6a, 0x3d, 0xb7, 0xe5, 0x6d, 0x59, 0x3e, 0x09,
292 0xb5, 0xe3, 0x3e, 0xfc, 0x50, 0x56, 0xe9, 0x50, 0x42, 0x7c, 0xe7, 0xf0,
293 0x19, 0xbd, 0x31, 0xa7, 0x85, 0x47, 0xb3, 0xe9, 0xb3, 0x50, 0x3c, 0xc9,
294 0x32, 0x37, 0x1a, 0x93, 0x78, 0x48, 0x78, 0x82, 0xde, 0xad, 0x5c, 0xf2,
295 0xcf, 0xf2, 0xbb, 0x2c, 0x44, 0x05, 0x7f, 0x4a, 0xf9, 0xb1, 0x2b, 0xdd,
davidben7dad2a32016-03-01 23:47:47296 0x49, 0xf6, 0x7e, 0xd0, 0x42, 0xaa, 0x14, 0x3c, 0x24, 0x77, 0xb4,
297 };
298 static const uint8_t kOpenSSLPublicKey[] = {
[email protected]dc06f752014-08-06 23:11:09299 0x30, 0x59, 0x30, 0x13, 0x06, 0x07, 0x2a, 0x86, 0x48, 0xce, 0x3d, 0x02,
300 0x01, 0x06, 0x08, 0x2a, 0x86, 0x48, 0xce, 0x3d, 0x03, 0x01, 0x07, 0x03,
301 0x42, 0x00, 0x04, 0xb9, 0xda, 0x0d, 0x71, 0x60, 0xb3, 0x63, 0x28, 0x22,
302 0x67, 0xe7, 0xe0, 0xa3, 0xf8, 0x00, 0x8e, 0x4c, 0x89, 0xed, 0x31, 0x34,
303 0xf6, 0xdb, 0xc4, 0xfe, 0x0b, 0x5d, 0xe1, 0x11, 0x39, 0x49, 0xa6, 0x50,
304 0xa8, 0xe3, 0x4a, 0xc0, 0x40, 0x88, 0xb8, 0x38, 0x3f, 0x56, 0xfb, 0x33,
305 0x8d, 0xd4, 0x64, 0x91, 0xd6, 0x15, 0x77, 0x42, 0x27, 0xc5, 0xaa, 0x44,
davidben7dad2a32016-03-01 23:47:47306 0xff, 0xab, 0x4d, 0xb5, 0x7e, 0x25, 0x3d,
307 };
308 static const uint8_t kOpenSSLRawPublicKey[] = {
309 0xb9, 0xda, 0x0d, 0x71, 0x60, 0xb3, 0x63, 0x28, 0x22, 0x67, 0xe7,
310 0xe0, 0xa3, 0xf8, 0x00, 0x8e, 0x4c, 0x89, 0xed, 0x31, 0x34, 0xf6,
311 0xdb, 0xc4, 0xfe, 0x0b, 0x5d, 0xe1, 0x11, 0x39, 0x49, 0xa6, 0x50,
312 0xa8, 0xe3, 0x4a, 0xc0, 0x40, 0x88, 0xb8, 0x38, 0x3f, 0x56, 0xfb,
313 0x33, 0x8d, 0xd4, 0x64, 0x91, 0xd6, 0x15, 0x77, 0x42, 0x27, 0xc5,
314 0xaa, 0x44, 0xff, 0xab, 0x4d, 0xb5, 0x7e, 0x25, 0x3d,
315 };
[email protected]dc06f752014-08-06 23:11:09316
thakisd1a18472016-04-08 22:30:41317 std::unique_ptr<crypto::ECPrivateKey> keypair_openssl(
[email protected]dc06f752014-08-06 23:11:09318 crypto::ECPrivateKey::CreateFromEncryptedPrivateKeyInfo(
David Benjaminb86b0a082017-09-21 16:55:36319 std::vector<uint8_t>(std::begin(kOpenSSLKey),
320 std::end(kOpenSSLKey))));
[email protected]dc06f752014-08-06 23:11:09321
rsleeviffe5a132016-06-28 01:51:52322 EXPECT_TRUE(keypair_openssl);
davidben7dad2a32016-03-01 23:47:47323
324 std::vector<uint8_t> public_key;
325 EXPECT_TRUE(keypair_openssl->ExportPublicKey(&public_key));
326 EXPECT_EQ(std::vector<uint8_t>(std::begin(kOpenSSLPublicKey),
327 std::end(kOpenSSLPublicKey)),
328 public_key);
329
330 std::string raw_public_key;
331 EXPECT_TRUE(keypair_openssl->ExportRawPublicKey(&raw_public_key));
332 EXPECT_EQ(std::string(reinterpret_cast<const char*>(kOpenSSLRawPublicKey),
Avi Drissman34f6b422018-12-25 20:29:39333 base::size(kOpenSSLRawPublicKey)),
davidben7dad2a32016-03-01 23:47:47334 raw_public_key);
[email protected]dc06f752014-08-06 23:11:09335}
336
337// The Android code writes out Channel IDs differently from the NSS
338// implementation; the empty password is converted to "\0\0". The OpenSSL port
339// should support either.
[email protected]dc06f752014-08-06 23:11:09340TEST(ECPrivateKeyUnitTest, LoadOldOpenSSLKeyTest) {
davidben7dad2a32016-03-01 23:47:47341 static const uint8_t kOpenSSLKey[] = {
[email protected]cdddc0f92014-03-22 02:42:47342 0x30, 0x82, 0x01, 0xa1, 0x30, 0x1b, 0x06, 0x0a, 0x2a, 0x86, 0x48, 0x86,
343 0xf7, 0x0d, 0x01, 0x0c, 0x01, 0x03, 0x30, 0x0d, 0x04, 0x08, 0x86, 0xaa,
344 0xd7, 0xdf, 0x3b, 0x91, 0x97, 0x60, 0x02, 0x01, 0x01, 0x04, 0x82, 0x01,
345 0x80, 0xcb, 0x2a, 0x14, 0xaa, 0x4f, 0x38, 0x4c, 0xe1, 0x49, 0x00, 0xe2,
346 0x1a, 0x3a, 0x75, 0x87, 0x7e, 0x3d, 0xea, 0x4d, 0x53, 0xd4, 0x46, 0x47,
347 0x23, 0x8f, 0xa1, 0x72, 0x51, 0x92, 0x86, 0x8b, 0xeb, 0x53, 0xe6, 0x6a,
348 0x0a, 0x6b, 0xb6, 0xa0, 0xdc, 0x0f, 0xdc, 0x20, 0xc3, 0x45, 0x85, 0xf1,
349 0x95, 0x90, 0x5c, 0xf4, 0xfa, 0xee, 0x47, 0xaf, 0x35, 0xd0, 0xd0, 0xd3,
350 0x14, 0xde, 0x0d, 0xca, 0x1b, 0xd3, 0xbb, 0x20, 0xec, 0x9d, 0x6a, 0xd4,
351 0xc1, 0xce, 0x60, 0x81, 0xab, 0x0c, 0x72, 0x10, 0xfa, 0x28, 0x3c, 0xac,
352 0x87, 0x7b, 0x82, 0x85, 0x00, 0xb8, 0x58, 0x9c, 0x07, 0xc4, 0x7d, 0xa9,
353 0xc5, 0x94, 0x95, 0xf7, 0x23, 0x93, 0x3f, 0xed, 0xef, 0x92, 0x55, 0x25,
354 0x74, 0xbb, 0xd3, 0xd1, 0x67, 0x3b, 0x3d, 0x5a, 0xfe, 0x84, 0xf8, 0x97,
355 0x7d, 0x7c, 0x01, 0xc7, 0xd7, 0x0d, 0xf8, 0xc3, 0x6d, 0xd6, 0xf1, 0xaa,
356 0x9d, 0x1f, 0x69, 0x97, 0x45, 0x06, 0xc4, 0x1c, 0x95, 0x3c, 0xe0, 0xef,
357 0x11, 0xb2, 0xb3, 0x72, 0x91, 0x9e, 0x7d, 0x0f, 0x7f, 0xc8, 0xf6, 0x64,
358 0x49, 0x5e, 0x3c, 0x53, 0x37, 0x79, 0x03, 0x1c, 0x3f, 0x29, 0x6c, 0x6b,
359 0xea, 0x4c, 0x35, 0x9b, 0x6d, 0x1b, 0x59, 0x43, 0x4c, 0x14, 0x47, 0x2a,
360 0x36, 0x39, 0x2a, 0xd8, 0x96, 0x90, 0xdc, 0xfc, 0xd2, 0xdd, 0x23, 0x0e,
361 0x2c, 0xb3, 0x83, 0xf9, 0xf2, 0xe3, 0xe6, 0x99, 0x53, 0x57, 0x33, 0xc5,
362 0x5f, 0xf9, 0xfd, 0x56, 0x0b, 0x32, 0xd4, 0xf3, 0x9d, 0x5b, 0x34, 0xe5,
363 0x94, 0xbf, 0xb6, 0xc0, 0xce, 0xe1, 0x73, 0x5c, 0x02, 0x7a, 0x4c, 0xed,
364 0xde, 0x23, 0x38, 0x89, 0x9f, 0xcd, 0x51, 0xf3, 0x90, 0x80, 0xd3, 0x4b,
365 0x83, 0xd3, 0xee, 0xf2, 0x9e, 0x35, 0x91, 0xa5, 0xa3, 0xc0, 0x5c, 0xce,
366 0xdb, 0xaa, 0x70, 0x1e, 0x1d, 0xc1, 0x44, 0xea, 0x3b, 0xa7, 0x5a, 0x11,
367 0xd1, 0xf3, 0xf3, 0xd0, 0xf4, 0x5a, 0xc4, 0x99, 0xaf, 0x8d, 0xe2, 0xbc,
368 0xa2, 0xb9, 0x3d, 0x86, 0x5e, 0xba, 0xa0, 0xdf, 0x78, 0x81, 0x7c, 0x54,
369 0x31, 0xe3, 0x98, 0xb5, 0x46, 0xcb, 0x4d, 0x26, 0x4b, 0xf8, 0xac, 0x3a,
370 0x54, 0x1b, 0x77, 0x5a, 0x18, 0xa5, 0x43, 0x0e, 0x14, 0xde, 0x7b, 0xb7,
371 0x4e, 0x45, 0x99, 0x03, 0xd1, 0x3d, 0x18, 0xb2, 0x36, 0x00, 0x48, 0x07,
372 0x72, 0xbb, 0x4f, 0x21, 0x25, 0x3e, 0xda, 0x25, 0x24, 0x5b, 0xc8, 0xa0,
373 0x28, 0xd5, 0x9b, 0x96, 0x87, 0x07, 0x77, 0x84, 0xff, 0xd7, 0xac, 0x71,
374 0xf6, 0x61, 0x63, 0x0b, 0xfb, 0x42, 0xfd, 0x52, 0xf4, 0xc4, 0x35, 0x0c,
375 0xc2, 0xc1, 0x55, 0x22, 0x42, 0x2f, 0x13, 0x7d, 0x93, 0x27, 0xc8, 0x11,
376 0x35, 0xc5, 0xe3, 0xc5, 0xaa, 0x15, 0x3c, 0xac, 0x30, 0xbc, 0x45, 0x16,
davidben7dad2a32016-03-01 23:47:47377 0xed,
378 };
[email protected]cdddc0f92014-03-22 02:42:47379
thakisd1a18472016-04-08 22:30:41380 std::unique_ptr<crypto::ECPrivateKey> keypair_openssl(
[email protected]cdddc0f92014-03-22 02:42:47381 crypto::ECPrivateKey::CreateFromEncryptedPrivateKeyInfo(
David Benjaminb86b0a082017-09-21 16:55:36382 std::vector<uint8_t>(std::begin(kOpenSSLKey),
383 std::end(kOpenSSLKey))));
[email protected]cdddc0f92014-03-22 02:42:47384
rsleeviffe5a132016-06-28 01:51:52385 EXPECT_TRUE(keypair_openssl);
[email protected]cdddc0f92014-03-22 02:42:47386}