diff options
author | lloyd <[email protected]> | 2014-01-10 23:07:16 +0000 |
---|---|---|
committer | lloyd <[email protected]> | 2014-01-10 23:07:16 +0000 |
commit | ad6555f522ae16f6284e8dafa02f630b88bcf289 (patch) | |
tree | bd63c51dbeab75eb0f90c72589bc922141237056 /src/tests/test_rw.cpp | |
parent | 6894dca64c04936d07048c0e8cbf7e25858548c3 (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.cpp | 77 |
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; + } + |