Home | History | Annotate | Download | only in crypto
      1 // 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/rsa_private_key.h"
      6 
      7 #include "base/memory/scoped_ptr.h"
      8 #include "testing/gtest/include/gtest/gtest.h"
      9 
     10 namespace {
     11 
     12 const uint8 kTestPrivateKeyInfo[] = {
     13   0x30, 0x82, 0x02, 0x78, 0x02, 0x01, 0x00, 0x30,
     14   0x0d, 0x06, 0x09, 0x2a, 0x86, 0x48, 0x86, 0xf7,
     15   0x0d, 0x01, 0x01, 0x01, 0x05, 0x00, 0x04, 0x82,
     16   0x02, 0x62, 0x30, 0x82, 0x02, 0x5e, 0x02, 0x01,
     17   0x00, 0x02, 0x81, 0x81, 0x00, 0xb8, 0x7f, 0x2b,
     18   0x20, 0xdc, 0x7c, 0x9b, 0x0c, 0xdc, 0x51, 0x61,
     19   0x99, 0x0d, 0x36, 0x0f, 0xd4, 0x66, 0x88, 0x08,
     20   0x55, 0x84, 0xd5, 0x3a, 0xbf, 0x2b, 0xa4, 0x64,
     21   0x85, 0x7b, 0x0c, 0x04, 0x13, 0x3f, 0x8d, 0xf4,
     22   0xbc, 0x38, 0x0d, 0x49, 0xfe, 0x6b, 0xc4, 0x5a,
     23   0xb0, 0x40, 0x53, 0x3a, 0xd7, 0x66, 0x09, 0x0f,
     24   0x9e, 0x36, 0x74, 0x30, 0xda, 0x8a, 0x31, 0x4f,
     25   0x1f, 0x14, 0x50, 0xd7, 0xc7, 0x20, 0x94, 0x17,
     26   0xde, 0x4e, 0xb9, 0x57, 0x5e, 0x7e, 0x0a, 0xe5,
     27   0xb2, 0x65, 0x7a, 0x89, 0x4e, 0xb6, 0x47, 0xff,
     28   0x1c, 0xbd, 0xb7, 0x38, 0x13, 0xaf, 0x47, 0x85,
     29   0x84, 0x32, 0x33, 0xf3, 0x17, 0x49, 0xbf, 0xe9,
     30   0x96, 0xd0, 0xd6, 0x14, 0x6f, 0x13, 0x8d, 0xc5,
     31   0xfc, 0x2c, 0x72, 0xba, 0xac, 0xea, 0x7e, 0x18,
     32   0x53, 0x56, 0xa6, 0x83, 0xa2, 0xce, 0x93, 0x93,
     33   0xe7, 0x1f, 0x0f, 0xe6, 0x0f, 0x02, 0x03, 0x01,
     34   0x00, 0x01, 0x02, 0x81, 0x80, 0x03, 0x61, 0x89,
     35   0x37, 0xcb, 0xf2, 0x98, 0xa0, 0xce, 0xb4, 0xcb,
     36   0x16, 0x13, 0xf0, 0xe6, 0xaf, 0x5c, 0xc5, 0xa7,
     37   0x69, 0x71, 0xca, 0xba, 0x8d, 0xe0, 0x4d, 0xdd,
     38   0xed, 0xb8, 0x48, 0x8b, 0x16, 0x93, 0x36, 0x95,
     39   0xc2, 0x91, 0x40, 0x65, 0x17, 0xbd, 0x7f, 0xd6,
     40   0xad, 0x9e, 0x30, 0x28, 0x46, 0xe4, 0x3e, 0xcc,
     41   0x43, 0x78, 0xf9, 0xfe, 0x1f, 0x33, 0x23, 0x1e,
     42   0x31, 0x12, 0x9d, 0x3c, 0xa7, 0x08, 0x82, 0x7b,
     43   0x7d, 0x25, 0x4e, 0x5e, 0x19, 0xa8, 0x9b, 0xed,
     44   0x86, 0xb2, 0xcb, 0x3c, 0xfe, 0x4e, 0xa1, 0xfa,
     45   0x62, 0x87, 0x3a, 0x17, 0xf7, 0x60, 0xec, 0x38,
     46   0x29, 0xe8, 0x4f, 0x34, 0x9f, 0x76, 0x9d, 0xee,
     47   0xa3, 0xf6, 0x85, 0x6b, 0x84, 0x43, 0xc9, 0x1e,
     48   0x01, 0xff, 0xfd, 0xd0, 0x29, 0x4c, 0xfa, 0x8e,
     49   0x57, 0x0c, 0xc0, 0x71, 0xa5, 0xbb, 0x88, 0x46,
     50   0x29, 0x5c, 0xc0, 0x4f, 0x01, 0x02, 0x41, 0x00,
     51   0xf5, 0x83, 0xa4, 0x64, 0x4a, 0xf2, 0xdd, 0x8c,
     52   0x2c, 0xed, 0xa8, 0xd5, 0x60, 0x5a, 0xe4, 0xc7,
     53   0xcc, 0x61, 0xcd, 0x38, 0x42, 0x20, 0xd3, 0x82,
     54   0x18, 0xf2, 0x35, 0x00, 0x72, 0x2d, 0xf7, 0x89,
     55   0x80, 0x67, 0xb5, 0x93, 0x05, 0x5f, 0xdd, 0x42,
     56   0xba, 0x16, 0x1a, 0xea, 0x15, 0xc6, 0xf0, 0xb8,
     57   0x8c, 0xbc, 0xbf, 0x54, 0x9e, 0xf1, 0xc1, 0xb2,
     58   0xb3, 0x8b, 0xb6, 0x26, 0x02, 0x30, 0xc4, 0x81,
     59   0x02, 0x41, 0x00, 0xc0, 0x60, 0x62, 0x80, 0xe1,
     60   0x22, 0x78, 0xf6, 0x9d, 0x83, 0x18, 0xeb, 0x72,
     61   0x45, 0xd7, 0xc8, 0x01, 0x7f, 0xa9, 0xca, 0x8f,
     62   0x7d, 0xd6, 0xb8, 0x31, 0x2b, 0x84, 0x7f, 0x62,
     63   0xd9, 0xa9, 0x22, 0x17, 0x7d, 0x06, 0x35, 0x6c,
     64   0xf3, 0xc1, 0x94, 0x17, 0x85, 0x5a, 0xaf, 0x9c,
     65   0x5c, 0x09, 0x3c, 0xcf, 0x2f, 0x44, 0x9d, 0xb6,
     66   0x52, 0x68, 0x5f, 0xf9, 0x59, 0xc8, 0x84, 0x2b,
     67   0x39, 0x22, 0x8f, 0x02, 0x41, 0x00, 0xb2, 0x04,
     68   0xe2, 0x0e, 0x56, 0xca, 0x03, 0x1a, 0xc0, 0xf9,
     69   0x12, 0x92, 0xa5, 0x6b, 0x42, 0xb8, 0x1c, 0xda,
     70   0x4d, 0x93, 0x9d, 0x5f, 0x6f, 0xfd, 0xc5, 0x58,
     71   0xda, 0x55, 0x98, 0x74, 0xfc, 0x28, 0x17, 0x93,
     72   0x1b, 0x75, 0x9f, 0x50, 0x03, 0x7f, 0x7e, 0xae,
     73   0xc8, 0x95, 0x33, 0x75, 0x2c, 0xd6, 0xa4, 0x35,
     74   0xb8, 0x06, 0x03, 0xba, 0x08, 0x59, 0x2b, 0x17,
     75   0x02, 0xdc, 0x4c, 0x7a, 0x50, 0x01, 0x02, 0x41,
     76   0x00, 0x9d, 0xdb, 0x39, 0x59, 0x09, 0xe4, 0x30,
     77   0xa0, 0x24, 0xf5, 0xdb, 0x2f, 0xf0, 0x2f, 0xf1,
     78   0x75, 0x74, 0x0d, 0x5e, 0xb5, 0x11, 0x73, 0xb0,
     79   0x0a, 0xaa, 0x86, 0x4c, 0x0d, 0xff, 0x7e, 0x1d,
     80   0xb4, 0x14, 0xd4, 0x09, 0x91, 0x33, 0x5a, 0xfd,
     81   0xa0, 0x58, 0x80, 0x9b, 0xbe, 0x78, 0x2e, 0x69,
     82   0x82, 0x15, 0x7c, 0x72, 0xf0, 0x7b, 0x18, 0x39,
     83   0xff, 0x6e, 0xeb, 0xc6, 0x86, 0xf5, 0xb4, 0xc7,
     84   0x6f, 0x02, 0x41, 0x00, 0x8d, 0x1a, 0x37, 0x0f,
     85   0x76, 0xc4, 0x82, 0xfa, 0x5c, 0xc3, 0x79, 0x35,
     86   0x3e, 0x70, 0x8a, 0xbf, 0x27, 0x49, 0xb0, 0x99,
     87   0x63, 0xcb, 0x77, 0x5f, 0xa8, 0x82, 0x65, 0xf6,
     88   0x03, 0x52, 0x51, 0xf1, 0xae, 0x2e, 0x05, 0xb3,
     89   0xc6, 0xa4, 0x92, 0xd1, 0xce, 0x6c, 0x72, 0xfb,
     90   0x21, 0xb3, 0x02, 0x87, 0xe4, 0xfd, 0x61, 0xca,
     91   0x00, 0x42, 0x19, 0xf0, 0xda, 0x5a, 0x53, 0xe3,
     92   0xb1, 0xc5, 0x15, 0xf3
     93 };
     94 
     95 }  // namespace
     96 
     97 // Generate random private keys with two different sizes. Reimport, then
     98 // export them again. We should get back the same exact bytes.
     99 TEST(RSAPrivateKeyUnitTest, InitRandomTest) {
    100   scoped_ptr<crypto::RSAPrivateKey> keypair1(
    101       crypto::RSAPrivateKey::Create(1024));
    102   scoped_ptr<crypto::RSAPrivateKey> keypair2(
    103       crypto::RSAPrivateKey::Create(2048));
    104   ASSERT_TRUE(keypair1.get());
    105   ASSERT_TRUE(keypair2.get());
    106 
    107   std::vector<uint8> privkey1;
    108   std::vector<uint8> privkey2;
    109   std::vector<uint8> pubkey1;
    110   std::vector<uint8> pubkey2;
    111 
    112   ASSERT_TRUE(keypair1->ExportPrivateKey(&privkey1));
    113   ASSERT_TRUE(keypair2->ExportPrivateKey(&privkey2));
    114   ASSERT_TRUE(keypair1->ExportPublicKey(&pubkey1));
    115   ASSERT_TRUE(keypair2->ExportPublicKey(&pubkey2));
    116 
    117   scoped_ptr<crypto::RSAPrivateKey> keypair3(
    118       crypto::RSAPrivateKey::CreateFromPrivateKeyInfo(privkey1));
    119   scoped_ptr<crypto::RSAPrivateKey> keypair4(
    120       crypto::RSAPrivateKey::CreateFromPrivateKeyInfo(privkey2));
    121   ASSERT_TRUE(keypair3.get());
    122   ASSERT_TRUE(keypair4.get());
    123 
    124   std::vector<uint8> privkey3;
    125   std::vector<uint8> privkey4;
    126   ASSERT_TRUE(keypair3->ExportPrivateKey(&privkey3));
    127   ASSERT_TRUE(keypair4->ExportPrivateKey(&privkey4));
    128 
    129   ASSERT_EQ(privkey1.size(), privkey3.size());
    130   ASSERT_EQ(privkey2.size(), privkey4.size());
    131   ASSERT_TRUE(0 == memcmp(&privkey1.front(), &privkey3.front(),
    132                           privkey1.size()));
    133   ASSERT_TRUE(0 == memcmp(&privkey2.front(), &privkey4.front(),
    134                           privkey2.size()));
    135 }
    136 
    137 // Test Copy() method.
    138 TEST(RSAPrivateKeyUnitTest, CopyTest) {
    139   std::vector<uint8> input(
    140       kTestPrivateKeyInfo, kTestPrivateKeyInfo + sizeof(kTestPrivateKeyInfo));
    141 
    142   scoped_ptr<crypto::RSAPrivateKey> key(
    143       crypto::RSAPrivateKey::CreateFromPrivateKeyInfo(input));
    144 
    145   scoped_ptr<crypto::RSAPrivateKey> key_copy(key->Copy());
    146   ASSERT_TRUE(key_copy.get());
    147 
    148   std::vector<uint8> privkey_copy;
    149   ASSERT_TRUE(key_copy->ExportPrivateKey(&privkey_copy));
    150   ASSERT_EQ(input, privkey_copy);
    151 }
    152 
    153 
    154 // Verify that generated public keys look good. This test data was generated
    155 // with the openssl command line tool.
    156 TEST(RSAPrivateKeyUnitTest, PublicKeyTest) {
    157   const uint8 expected_public_key_info[] = {
    158     0x30, 0x81, 0x9f, 0x30, 0x0d, 0x06, 0x09, 0x2a,
    159     0x86, 0x48, 0x86, 0xf7, 0x0d, 0x01, 0x01, 0x01,
    160     0x05, 0x00, 0x03, 0x81, 0x8d, 0x00, 0x30, 0x81,
    161     0x89, 0x02, 0x81, 0x81, 0x00, 0xb8, 0x7f, 0x2b,
    162     0x20, 0xdc, 0x7c, 0x9b, 0x0c, 0xdc, 0x51, 0x61,
    163     0x99, 0x0d, 0x36, 0x0f, 0xd4, 0x66, 0x88, 0x08,
    164     0x55, 0x84, 0xd5, 0x3a, 0xbf, 0x2b, 0xa4, 0x64,
    165     0x85, 0x7b, 0x0c, 0x04, 0x13, 0x3f, 0x8d, 0xf4,
    166     0xbc, 0x38, 0x0d, 0x49, 0xfe, 0x6b, 0xc4, 0x5a,
    167     0xb0, 0x40, 0x53, 0x3a, 0xd7, 0x66, 0x09, 0x0f,
    168     0x9e, 0x36, 0x74, 0x30, 0xda, 0x8a, 0x31, 0x4f,
    169     0x1f, 0x14, 0x50, 0xd7, 0xc7, 0x20, 0x94, 0x17,
    170     0xde, 0x4e, 0xb9, 0x57, 0x5e, 0x7e, 0x0a, 0xe5,
    171     0xb2, 0x65, 0x7a, 0x89, 0x4e, 0xb6, 0x47, 0xff,
    172     0x1c, 0xbd, 0xb7, 0x38, 0x13, 0xaf, 0x47, 0x85,
    173     0x84, 0x32, 0x33, 0xf3, 0x17, 0x49, 0xbf, 0xe9,
    174     0x96, 0xd0, 0xd6, 0x14, 0x6f, 0x13, 0x8d, 0xc5,
    175     0xfc, 0x2c, 0x72, 0xba, 0xac, 0xea, 0x7e, 0x18,
    176     0x53, 0x56, 0xa6, 0x83, 0xa2, 0xce, 0x93, 0x93,
    177     0xe7, 0x1f, 0x0f, 0xe6, 0x0f, 0x02, 0x03, 0x01,
    178     0x00, 0x01
    179   };
    180 
    181   std::vector<uint8> input(
    182       kTestPrivateKeyInfo, kTestPrivateKeyInfo + sizeof(kTestPrivateKeyInfo));
    183 
    184   scoped_ptr<crypto::RSAPrivateKey> key(
    185       crypto::RSAPrivateKey::CreateFromPrivateKeyInfo(input));
    186   ASSERT_TRUE(key.get());
    187 
    188   std::vector<uint8> output;
    189   ASSERT_TRUE(key->ExportPublicKey(&output));
    190 
    191   ASSERT_TRUE(
    192       memcmp(expected_public_key_info, &output.front(), output.size()) == 0);
    193 }
    194 
    195 // These two test keys each contain an integer that has 0x00 for its most
    196 // significant byte. When encoded as ASN.1, this byte is dropped and there are
    197 // two interesting sub-cases. When the sign bit of the integer is set, an extra
    198 // null byte is added back to force the encoded value to be positive. When the
    199 // sign bit is not set, the encoded integer is just left shorter than usual.
    200 // See also: http://code.google.com/p/chromium/issues/detail?id=14877.
    201 //
    202 // Before we were handling this correctly, we would see one of two failures:
    203 // * RSAPrivateKey::CreateFromPrivateKeyInfo would return null because the
    204 //   underlying windows API failed to import the key.
    205 // * The import would succeed, but incorrectly interpret the data. On export,
    206 //   the key would contain different values.
    207 //
    208 // This test case verifies these two failures modes don't occur.
    209 TEST(RSAPrivateKeyUnitTest, ShortIntegers) {
    210   const uint8 short_integer_with_high_bit[] = {
    211     0x30, 0x82, 0x02, 0x77, 0x02, 0x01, 0x00, 0x30,
    212     0x0d, 0x06, 0x09, 0x2a, 0x86, 0x48, 0x86, 0xf7,
    213     0x0d, 0x01, 0x01, 0x01, 0x05, 0x00, 0x04, 0x82,
    214     0x02, 0x61, 0x30, 0x82, 0x02, 0x5d, 0x02, 0x01,
    215     0x00, 0x02, 0x81, 0x81, 0x00, 0x92, 0x59, 0x32,
    216     0x7d, 0x8e, 0xaf, 0x2e, 0xd5, 0xb2, 0x5c, 0x67,
    217     0xc8, 0x7d, 0x48, 0xb7, 0x84, 0x12, 0xd0, 0x76,
    218     0xda, 0xe1, 0xa3, 0x1e, 0x40, 0x01, 0x14, 0x5c,
    219     0xef, 0x26, 0x6e, 0x28, 0xa2, 0xf7, 0xa5, 0xb4,
    220     0x02, 0x37, 0xd0, 0x53, 0x10, 0xcb, 0x7c, 0x6a,
    221     0xf4, 0x53, 0x9f, 0xb8, 0xe0, 0x83, 0x93, 0xd1,
    222     0x19, 0xd8, 0x28, 0xd1, 0xd1, 0xd8, 0x87, 0x8f,
    223     0x92, 0xfd, 0x73, 0xc0, 0x4d, 0x3e, 0x07, 0x22,
    224     0x1f, 0xc1, 0x20, 0xb0, 0x70, 0xb2, 0x3b, 0xea,
    225     0xb1, 0xe5, 0x0a, 0xfd, 0x56, 0x49, 0x5e, 0x39,
    226     0x90, 0x91, 0xce, 0x04, 0x83, 0x29, 0xaa, 0xfd,
    227     0x12, 0xa4, 0x42, 0x26, 0x6c, 0x6e, 0x79, 0x70,
    228     0x77, 0x03, 0xb2, 0x07, 0x01, 0x3d, 0x85, 0x81,
    229     0x95, 0x9e, 0xda, 0x5a, 0xa3, 0xf4, 0x2d, 0x38,
    230     0x04, 0x58, 0xf5, 0x6b, 0xc9, 0xf1, 0xb5, 0x65,
    231     0xfe, 0x66, 0x0d, 0xa2, 0xd5, 0x02, 0x03, 0x01,
    232     0x00, 0x01, 0x02, 0x81, 0x80, 0x5e, 0x01, 0x5f,
    233     0xb6, 0x59, 0x1d, 0xdc, 0x36, 0xb6, 0x60, 0x36,
    234     0xe6, 0x08, 0xdb, 0xd9, 0xcd, 0xc3, 0x8c, 0x16,
    235     0x9c, 0x98, 0x8d, 0x7f, 0xd3, 0xdb, 0x1d, 0xaa,
    236     0x68, 0x8f, 0xc5, 0xf8, 0xe2, 0x5d, 0xb3, 0x19,
    237     0xc2, 0xc6, 0xf9, 0x51, 0x32, 0x1b, 0x93, 0x6a,
    238     0xdc, 0x50, 0x8e, 0xeb, 0x61, 0x84, 0x03, 0x42,
    239     0x30, 0x98, 0xb1, 0xf7, 0xbd, 0x14, 0x9a, 0x57,
    240     0x36, 0x33, 0x09, 0xd4, 0x3e, 0x90, 0xda, 0xef,
    241     0x09, 0x6e, 0xef, 0x49, 0xb6, 0x60, 0x68, 0x5e,
    242     0x54, 0x17, 0x25, 0x5b, 0x37, 0xe3, 0x35, 0x63,
    243     0x5b, 0x60, 0x3c, 0xbd, 0x50, 0xdf, 0x46, 0x43,
    244     0x08, 0xa4, 0x71, 0x21, 0xf1, 0x30, 0x71, 0xdc,
    245     0xda, 0xd7, 0x6f, 0xd2, 0x18, 0xbd, 0x39, 0xf1,
    246     0xe1, 0xbe, 0xa8, 0x8d, 0x62, 0xdf, 0xa2, 0x3e,
    247     0xb6, 0x15, 0x26, 0xb6, 0x57, 0xbd, 0x63, 0xdb,
    248     0xc1, 0x91, 0xec, 0xb8, 0x01, 0x02, 0x41, 0x00,
    249     0xc6, 0x1a, 0x06, 0x48, 0xf2, 0x12, 0x1c, 0x9f,
    250     0x74, 0x20, 0x5c, 0x85, 0xa2, 0xda, 0xe5, 0x62,
    251     0x96, 0x8d, 0x22, 0x7b, 0x78, 0x73, 0xea, 0xbb,
    252     0x9f, 0x59, 0x42, 0x13, 0x15, 0xc8, 0x11, 0x50,
    253     0x6c, 0x55, 0xf6, 0xdf, 0x8b, 0xfe, 0xc7, 0xdd,
    254     0xa8, 0xca, 0x54, 0x41, 0xe8, 0xce, 0xbe, 0x7d,
    255     0xbd, 0xe2, 0x13, 0x4b, 0x5b, 0x61, 0xeb, 0x69,
    256     0x6c, 0xb1, 0x9b, 0x28, 0x68, 0x5b, 0xd6, 0x01,
    257     0x02, 0x41, 0x00, 0xbd, 0x1e, 0xfe, 0x51, 0x99,
    258     0xb6, 0xe3, 0x84, 0xfe, 0xf1, 0x9e, 0xfd, 0x9c,
    259     0xe7, 0x86, 0x43, 0x68, 0x7f, 0x2f, 0x6a, 0x2a,
    260     0x4c, 0xae, 0xa6, 0x41, 0x1c, 0xf0, 0x10, 0x37,
    261     0x54, 0x23, 0xba, 0x05, 0x0d, 0x18, 0x27, 0x8d,
    262     0xb8, 0xe4, 0x8f, 0xf2, 0x25, 0x73, 0x8a, 0xd7,
    263     0x05, 0x98, 0x6b, 0x3d, 0x55, 0xb7, 0x6f, 0x7c,
    264     0xec, 0x77, 0x61, 0x54, 0x7b, 0xb6, 0x6b, 0x31,
    265     0xec, 0x94, 0xd5, 0x02, 0x41, 0x00, 0x90, 0xa2,
    266     0xa5, 0x9e, 0x12, 0xa7, 0x68, 0xa0, 0x7e, 0xdf,
    267     0xb5, 0xcd, 0x98, 0x26, 0xab, 0xbd, 0xbc, 0x5f,
    268     0xd5, 0x22, 0x42, 0xc2, 0x97, 0x4a, 0x5f, 0x40,
    269     0x82, 0xfe, 0x7e, 0x33, 0xb1, 0x78, 0x7f, 0x70,
    270     0x90, 0x2b, 0x8d, 0x01, 0xfb, 0x18, 0xfa, 0x48,
    271     0xa7, 0x15, 0xec, 0x0d, 0x2e, 0x85, 0x8d, 0xe2,
    272     0x86, 0xe5, 0xc9, 0x15, 0x88, 0x14, 0x53, 0xd8,
    273     0xa4, 0x88, 0xef, 0x10, 0xc6, 0x01, 0x02, 0x41,
    274     0x00, 0xba, 0xe4, 0xaf, 0x14, 0xfa, 0xdf, 0xf6,
    275     0xd5, 0xce, 0x8f, 0xfe, 0xbb, 0xc8, 0x5c, 0x30,
    276     0x9d, 0xda, 0xdd, 0x9d, 0x80, 0xc0, 0x0e, 0x89,
    277     0xa5, 0xb8, 0xc1, 0x1d, 0x28, 0x19, 0x55, 0x67,
    278     0xfd, 0x03, 0xd2, 0xdd, 0xe4, 0xf0, 0xb4, 0x20,
    279     0x03, 0x74, 0x9b, 0xb8, 0x24, 0x23, 0xbb, 0xde,
    280     0xd5, 0x53, 0x86, 0xaa, 0xc1, 0x5d, 0x65, 0xdd,
    281     0xcf, 0xec, 0x8a, 0x59, 0x4a, 0x73, 0xca, 0xc5,
    282     0x85, 0x02, 0x40, 0x00, 0xc4, 0x5e, 0x8d, 0xa4,
    283     0xea, 0xbb, 0x6a, 0x9b, 0xe6, 0x3a, 0x4d, 0xc1,
    284     0xdb, 0xe5, 0x52, 0x38, 0xf9, 0x59, 0x91, 0x2d,
    285     0x90, 0x82, 0xe3, 0x31, 0x1b, 0x48, 0xb7, 0x42,
    286     0xfa, 0x1d, 0x83, 0xd5, 0x3d, 0x02, 0xc2, 0x12,
    287     0x71, 0x10, 0x3a, 0xbd, 0x92, 0x8f, 0x9b, 0xa2,
    288     0x6b, 0x2d, 0x21, 0xa4, 0x65, 0xe9, 0xfa, 0x8c,
    289     0x30, 0x2a, 0x89, 0xce, 0xd0, 0xa7, 0x67, 0xd8,
    290     0x45, 0x84, 0xb0
    291   };
    292 
    293   const uint8 short_integer_without_high_bit[] = {
    294     0x30, 0x82, 0x02, 0x76, 0x02, 0x01, 0x00, 0x30,
    295     0x0d, 0x06, 0x09, 0x2a, 0x86, 0x48, 0x86, 0xf7,
    296     0x0d, 0x01, 0x01, 0x01, 0x05, 0x00, 0x04, 0x82,
    297     0x02, 0x60, 0x30, 0x82, 0x02, 0x5c, 0x02, 0x01,
    298     0x00, 0x02, 0x81, 0x81, 0x00, 0xc3, 0x9e, 0x8d,
    299     0xc4, 0x6d, 0x38, 0xe8, 0x0e, 0x9f, 0x84, 0x03,
    300     0x40, 0x8e, 0x81, 0x2e, 0x56, 0x67, 0x78, 0x11,
    301     0x85, 0x27, 0x81, 0x52, 0xf2, 0x1b, 0x3e, 0x5b,
    302     0xf8, 0xab, 0xfc, 0xaf, 0xca, 0x5c, 0x26, 0xd5,
    303     0xfa, 0xd4, 0x55, 0x50, 0x38, 0xb9, 0x9d, 0x89,
    304     0x92, 0x7e, 0x34, 0xcf, 0x37, 0x82, 0x48, 0x2d,
    305     0xaa, 0xc4, 0x6a, 0x0e, 0x93, 0xea, 0xad, 0x8a,
    306     0x33, 0xf0, 0x42, 0x23, 0xe0, 0x4c, 0x98, 0xbf,
    307     0x01, 0x00, 0x1b, 0xfe, 0x06, 0x15, 0xc6, 0xe3,
    308     0x80, 0x79, 0x6d, 0xfe, 0x48, 0xcd, 0x40, 0xbb,
    309     0xf9, 0x58, 0xe6, 0xbf, 0xd5, 0x4c, 0x29, 0x48,
    310     0x53, 0x78, 0x06, 0x03, 0x0d, 0x59, 0xf5, 0x20,
    311     0xe0, 0xe6, 0x8c, 0xb2, 0xf5, 0xd8, 0x61, 0x52,
    312     0x7e, 0x40, 0x83, 0xd7, 0x69, 0xae, 0xd7, 0x75,
    313     0x02, 0x2d, 0x49, 0xd5, 0x15, 0x5b, 0xf1, 0xd9,
    314     0x4d, 0x60, 0x7d, 0x62, 0xa5, 0x02, 0x03, 0x01,
    315     0x00, 0x01, 0x02, 0x7f, 0x6d, 0x45, 0x23, 0xeb,
    316     0x95, 0x17, 0x34, 0x88, 0xf6, 0x91, 0xc7, 0x3f,
    317     0x48, 0x5a, 0xe0, 0x87, 0x63, 0x44, 0xae, 0x84,
    318     0xb2, 0x8c, 0x8a, 0xc8, 0xb2, 0x6f, 0x22, 0xf0,
    319     0xc5, 0x21, 0x61, 0x10, 0xa8, 0x69, 0x09, 0x1e,
    320     0x13, 0x7d, 0x94, 0x52, 0x1b, 0x5c, 0xe4, 0x7b,
    321     0xf0, 0x03, 0x8f, 0xbc, 0x72, 0x09, 0xdf, 0x78,
    322     0x84, 0x3e, 0xb9, 0xe5, 0xe6, 0x31, 0x0a, 0x01,
    323     0xf9, 0x32, 0xf8, 0xd6, 0x57, 0xa3, 0x87, 0xe6,
    324     0xf5, 0x98, 0xbc, 0x8e, 0x41, 0xb9, 0x50, 0x17,
    325     0x7b, 0xd3, 0x97, 0x5a, 0x44, 0x3a, 0xee, 0xff,
    326     0x6b, 0xb3, 0x3a, 0x52, 0xe7, 0xa4, 0x96, 0x9a,
    327     0xf6, 0x83, 0xc8, 0x97, 0x1c, 0x63, 0xa1, 0xd6,
    328     0xb3, 0xa8, 0xb2, 0xc7, 0x73, 0x25, 0x0f, 0x58,
    329     0x36, 0xb9, 0x7a, 0x47, 0xa7, 0x4d, 0x30, 0xfe,
    330     0x4d, 0x74, 0x56, 0xe8, 0xfb, 0xd6, 0x50, 0xe5,
    331     0xe0, 0x28, 0x15, 0x02, 0x41, 0x00, 0xeb, 0x15,
    332     0x62, 0xb6, 0x37, 0x41, 0x7c, 0xc5, 0x00, 0x22,
    333     0x2c, 0x5a, 0x5e, 0xe4, 0xb2, 0x11, 0x87, 0x89,
    334     0xad, 0xf4, 0x57, 0x68, 0x90, 0xb7, 0x9f, 0xe2,
    335     0x79, 0x20, 0x6b, 0x98, 0x00, 0x0d, 0x3a, 0x3b,
    336     0xc1, 0xcd, 0x36, 0xf9, 0x27, 0xda, 0x40, 0x36,
    337     0x1d, 0xb8, 0x5c, 0x96, 0xeb, 0x04, 0x08, 0xe1,
    338     0x3f, 0xfa, 0x94, 0x8b, 0x0f, 0xa0, 0xff, 0xc1,
    339     0x51, 0xea, 0x90, 0xad, 0x15, 0xc7, 0x02, 0x41,
    340     0x00, 0xd5, 0x06, 0x45, 0xd7, 0x55, 0x63, 0x1a,
    341     0xf0, 0x89, 0x81, 0xae, 0x87, 0x23, 0xa2, 0x39,
    342     0xfe, 0x3d, 0x82, 0xc7, 0xcb, 0x15, 0xb9, 0xe3,
    343     0xe2, 0x5b, 0xc6, 0xd2, 0x55, 0xdd, 0xab, 0x55,
    344     0x29, 0x7c, 0xda, 0x0e, 0x1c, 0x09, 0xfc, 0x73,
    345     0x0d, 0x01, 0xed, 0x6d, 0x2f, 0x05, 0xd0, 0xd5,
    346     0x1d, 0xce, 0x18, 0x7f, 0xb0, 0xc8, 0x47, 0x77,
    347     0xd2, 0xa9, 0x9e, 0xfc, 0x39, 0x4b, 0x3d, 0x94,
    348     0x33, 0x02, 0x41, 0x00, 0x8f, 0x94, 0x09, 0x2d,
    349     0x17, 0x44, 0x75, 0x0a, 0xf1, 0x10, 0xee, 0x1b,
    350     0xe7, 0xd7, 0x2f, 0xf6, 0xca, 0xdc, 0x49, 0x15,
    351     0x72, 0x09, 0x58, 0x51, 0xfe, 0x61, 0xd8, 0xee,
    352     0xf7, 0x27, 0xe7, 0xe8, 0x2c, 0x47, 0xf1, 0x0f,
    353     0x00, 0x63, 0x5e, 0x76, 0xcb, 0x3f, 0x02, 0x19,
    354     0xe6, 0xda, 0xfa, 0x01, 0x05, 0xd7, 0x65, 0x37,
    355     0x0b, 0x60, 0x7f, 0x94, 0x2a, 0x80, 0x8d, 0x22,
    356     0x81, 0x68, 0x65, 0x63, 0x02, 0x41, 0x00, 0xc2,
    357     0xd4, 0x18, 0xde, 0x47, 0x9e, 0xfb, 0x8d, 0x91,
    358     0x05, 0xc5, 0x3c, 0x9d, 0xcf, 0x8a, 0x60, 0xc7,
    359     0x9b, 0x2b, 0xe5, 0xc6, 0xba, 0x1b, 0xfc, 0xf3,
    360     0xd9, 0x54, 0x97, 0xe9, 0xc4, 0x00, 0x80, 0x90,
    361     0x4a, 0xd2, 0x6a, 0xbc, 0x8b, 0x62, 0x22, 0x3c,
    362     0x68, 0x0c, 0xda, 0xdb, 0xe3, 0xd2, 0x76, 0x8e,
    363     0xff, 0x03, 0x12, 0x09, 0x2a, 0xac, 0x21, 0x44,
    364     0xb7, 0x3e, 0x91, 0x9c, 0x09, 0xf6, 0xd7, 0x02,
    365     0x41, 0x00, 0xc0, 0xa1, 0xbb, 0x70, 0xdc, 0xf8,
    366     0xeb, 0x17, 0x61, 0xd4, 0x8c, 0x7c, 0x3b, 0x82,
    367     0x91, 0x58, 0xff, 0xf9, 0x19, 0xac, 0x3a, 0x73,
    368     0xa7, 0x20, 0xe5, 0x22, 0x02, 0xc4, 0xf6, 0xb9,
    369     0xb9, 0x43, 0x53, 0x35, 0x88, 0xe1, 0x05, 0xb6,
    370     0x43, 0x9b, 0x39, 0xc8, 0x04, 0x4d, 0x2b, 0x01,
    371     0xf7, 0xe6, 0x1b, 0x8d, 0x7e, 0x89, 0xe3, 0x43,
    372     0xd4, 0xf3, 0xab, 0x28, 0xd4, 0x5a, 0x1f, 0x20,
    373     0xea, 0xbe
    374   };
    375 
    376   std::vector<uint8> input1;
    377   std::vector<uint8> input2;
    378 
    379   input1.resize(sizeof(short_integer_with_high_bit));
    380   input2.resize(sizeof(short_integer_without_high_bit));
    381 
    382   memcpy(&input1.front(), short_integer_with_high_bit,
    383          sizeof(short_integer_with_high_bit));
    384   memcpy(&input2.front(), short_integer_without_high_bit,
    385          sizeof(short_integer_without_high_bit));
    386 
    387   scoped_ptr<crypto::RSAPrivateKey> keypair1(
    388       crypto::RSAPrivateKey::CreateFromPrivateKeyInfo(input1));
    389   scoped_ptr<crypto::RSAPrivateKey> keypair2(
    390       crypto::RSAPrivateKey::CreateFromPrivateKeyInfo(input2));
    391   ASSERT_TRUE(keypair1.get());
    392   ASSERT_TRUE(keypair2.get());
    393 
    394   std::vector<uint8> output1;
    395   std::vector<uint8> output2;
    396   ASSERT_TRUE(keypair1->ExportPrivateKey(&output1));
    397   ASSERT_TRUE(keypair2->ExportPrivateKey(&output2));
    398 
    399   ASSERT_EQ(input1.size(), output1.size());
    400   ASSERT_EQ(input2.size(), output2.size());
    401   ASSERT_TRUE(0 == memcmp(&output1.front(), &input1.front(),
    402                           input1.size()));
    403   ASSERT_TRUE(0 == memcmp(&output2.front(), &input2.front(),
    404                           input2.size()));
    405 }
    406