summaryrefslogtreecommitdiffstats
path: root/base/crypto/signature_creator_unittest.cc
diff options
context:
space:
mode:
authoraa@chromium.org <aa@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-06-06 06:06:30 +0000
committeraa@chromium.org <aa@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-06-06 06:06:30 +0000
commit7eee790aef6fd764695a5f58ec6c29d7a757a8b8 (patch)
treefc28a2e1c4216f5ae8d65f1a75cdf568f4f2e446 /base/crypto/signature_creator_unittest.cc
parent6bab88335581bb13b989a5fb1a19cde10f88450f (diff)
downloadchromium_src-7eee790aef6fd764695a5f58ec6c29d7a757a8b8.zip
chromium_src-7eee790aef6fd764695a5f58ec6c29d7a757a8b8.tar.gz
chromium_src-7eee790aef6fd764695a5f58ec6c29d7a757a8b8.tar.bz2
Fix a bug in SignatureCreator and add some more tests.
Review URL: http://codereview.chromium.org/119277 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@17824 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'base/crypto/signature_creator_unittest.cc')
-rw-r--r--base/crypto/signature_creator_unittest.cc20
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());
+}