aboutsummaryrefslogtreecommitdiffstats
path: root/src/tests/test_rw.cpp
diff options
context:
space:
mode:
authorlloyd <[email protected]>2014-01-10 23:07:16 +0000
committerlloyd <[email protected]>2014-01-10 23:07:16 +0000
commitad6555f522ae16f6284e8dafa02f630b88bcf289 (patch)
treebd63c51dbeab75eb0f90c72589bc922141237056 /src/tests/test_rw.cpp
parent6894dca64c04936d07048c0e8cbf7e25858548c3 (diff)
Split up docs into the reference manual, the website, and everything else.
Add `website` target to makefile. Some progress towards fixing minimized builds. TLS now hard requires ECDSA and GCM since otherwise a minimized build has only insecure options. Remove boost_thread dependency in command line tool
Diffstat (limited to 'src/tests/test_rw.cpp')
-rw-r--r--src/tests/test_rw.cpp77
1 files changed, 77 insertions, 0 deletions
diff --git a/src/tests/test_rw.cpp b/src/tests/test_rw.cpp
new file mode 100644
index 000000000..4d3bc2d5b
--- /dev/null
+++ b/src/tests/test_rw.cpp
@@ -0,0 +1,77 @@
+#include "tests.h"
+#include "test_pubkey.h"
+
+#include <botan/auto_rng.h>
+#include <botan/pubkey.h>
+#include <botan/rw.h>
+#include <botan/hex.h>
+#include <iostream>
+#include <fstream>
+
+using namespace Botan;
+
+namespace {
+
+const std::string padding = "EMSA2(SHA-1)";
+
+size_t rw_sig_kat(const std::string& e,
+ const std::string& p,
+ const std::string& q,
+ const std::string& msg,
+ const std::string& signature)
+ {
+ AutoSeeded_RNG rng;
+
+ RW_PrivateKey privkey(rng, BigInt(p), BigInt(q), BigInt(e));
+
+ RW_PublicKey pubkey = privkey;
+
+ PK_Verifier verify(pubkey, padding);
+ PK_Signer sign(privkey, padding);
+
+ return validate_signature(verify, sign, "RW/" + padding, msg, rng, signature);
+ }
+
+size_t rw_sig_verify(const std::string& e,
+ const std::string& n,
+ const std::string& msg,
+ const std::string& signature)
+ {
+ AutoSeeded_RNG rng;
+
+ BigInt e_bn(e);
+ BigInt n_bn(n);
+
+ RW_PublicKey key(n_bn, e_bn);
+
+ PK_Verifier verify(key, padding);
+
+ if(!verify.verify_message(hex_decode(msg), hex_decode(signature)))
+ return 1;
+ return 0;
+ }
+
+}
+
+size_t test_rw()
+ {
+ std::ifstream rw_sig(PK_TEST_DATA_DIR "/rw_sig.vec");
+ std::ifstream rw_verify(PK_TEST_DATA_DIR "/rw_verify.vec");
+
+ size_t fails = 0;
+
+ fails += run_tests_bb(rw_sig, "RW Signature", "Signature", true,
+ [](std::map<std::string, std::string> m) -> size_t
+ {
+ return rw_sig_kat(m["E"], m["P"], m["Q"], m["Msg"], m["Signature"]);
+ });
+
+ fails += run_tests_bb(rw_verify, "RW Verify", "Signature", true,
+ [](std::map<std::string, std::string> m) -> size_t
+ {
+ return rw_sig_verify(m["E"], m["N"], m["Msg"], m["Signature"]);
+ });
+
+ return fails;
+ }
+