diff options
Diffstat (limited to 'base/crypto/signature_creator_unittest.cc')
-rw-r--r-- | base/crypto/signature_creator_unittest.cc | 20 |
1 files changed, 14 insertions, 6 deletions
diff --git a/base/crypto/signature_creator_unittest.cc b/base/crypto/signature_creator_unittest.cc index a65ad22..71aaba1 100644 --- a/base/crypto/signature_creator_unittest.cc +++ b/base/crypto/signature_creator_unittest.cc @@ -11,14 +11,20 @@ TEST(SignatureCreatorTest, BasicTest) { // Do a verify round trip. - scoped_ptr<base::RSAPrivateKey> key(base::RSAPrivateKey::Create(1024)); - ASSERT_TRUE(key.get()); + scoped_ptr<base::RSAPrivateKey> key_original( + base::RSAPrivateKey::Create(1024)); + ASSERT_TRUE(key_original.get()); + + std::vector<uint8> key_info; + key_original->ExportPrivateKey(&key_info); + scoped_ptr<base::RSAPrivateKey> key( + base::RSAPrivateKey::CreateFromPrivateKeyInfo(key_info)); scoped_ptr<base::SignatureCreator> signer( base::SignatureCreator::Create(key.get())); ASSERT_TRUE(signer.get()); - std::string data("Hello, world!"); + std::string data("Hello, World!"); ASSERT_TRUE(signer->Update(reinterpret_cast<const uint8*>(data.c_str()), data.size())); @@ -26,7 +32,7 @@ TEST(SignatureCreatorTest, BasicTest) { ASSERT_TRUE(signer->Final(&signature)); std::vector<uint8> public_key_info; - ASSERT_TRUE(key->ExportPublicKey(&public_key_info)); + ASSERT_TRUE(key_original->ExportPublicKey(&public_key_info)); // This is the algorithm ID for SHA-1 with RSA encryption. // TODO(aa): Factor this out into some shared location. @@ -39,6 +45,8 @@ TEST(SignatureCreatorTest, BasicTest) { kSHA1WithRSAAlgorithmID, sizeof(kSHA1WithRSAAlgorithmID), &signature.front(), signature.size(), &public_key_info.front(), public_key_info.size())); -} -// TODO(aa): Would be nice to test some well-known signatures. + verifier.VerifyUpdate(reinterpret_cast<const uint8*>(data.c_str()), + data.size()); + ASSERT_TRUE(verifier.VerifyFinal()); +} |