/* * (C) 2016 Jack Lloyd * * Botan is released under the Simplified BSD License (see license.txt) */ #include "tests.h" #if defined(BOTAN_HAS_FPE_FE1) #include #endif namespace Botan_Tests { #if defined(BOTAN_HAS_FPE_FE1) class FPE_FE1_Tests : public Text_Based_Test { public: FPE_FE1_Tests() : Text_Based_Test("fpe_fe1.vec", {"Mod", "In", "Out", "Key", "Tweak"}) {} Test::Result run_one_test(const std::string&, const VarMap& vars) override { const Botan::BigInt modulus = get_req_bn(vars, "Mod"); const Botan::BigInt input = get_req_bn(vars, "In"); const Botan::BigInt expected = get_req_bn(vars, "Out"); const std::vector key = get_req_bin(vars, "Key"); const std::vector tweak = get_req_bin(vars, "Tweak"); Test::Result result("FPE_FE1"); const Botan::BigInt got = Botan::FPE::fe1_encrypt(modulus, input, key, tweak); result.test_eq("ciphertext", got, expected); const Botan::BigInt decry = Botan::FPE::fe1_decrypt(modulus, got, key, tweak); result.test_eq("decrypted", decry, input); return result; } }; BOTAN_REGISTER_TEST("fpe_fe1", FPE_FE1_Tests); #endif }