aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorJack Lloyd <[email protected]>2018-01-30 19:55:13 -0500
committerJack Lloyd <[email protected]>2018-01-30 19:55:13 -0500
commit439bf83d41ee9176659c15f17d3ed7db1ad1437f (patch)
treee67883a3b73911987e4c3ce3d726be5b8b622a54 /src
parentd84a5b6f1a3ddff739c602d6dd80d5409ce992c8 (diff)
Add a few more tests of the test suite code
Diffstat (limited to 'src')
-rw-r--r--src/tests/test_tests.cpp58
1 files changed, 56 insertions, 2 deletions
diff --git a/src/tests/test_tests.cpp b/src/tests/test_tests.cpp
index 7b74dbbd8..63509d3f0 100644
--- a/src/tests/test_tests.cpp
+++ b/src/tests/test_tests.cpp
@@ -1,11 +1,15 @@
/*
-* (C) 2017 Jack Lloyd
+* (C) 2017,2018 Jack Lloyd
*
* Botan is released under the Simplified BSD License (see license.txt)
*/
#include "tests.h"
+#if defined(BOTAN_HAS_BIGINT)
+ #include <botan/bigint.h>
+#endif
+
namespace Botan_Tests {
/*
@@ -54,13 +58,27 @@ class Test_Tests final : public Test
{
Test::Result test_result("Testcase");
- std::vector<uint8_t> vec1(5), vec2(3);
+ std::vector<uint8_t> vec1(5), vec2(3, 9);
test_result.test_eq("test vectors equal", vec1, vec2);
verify_failure("test vectors equal", result, test_result);
}
{
Test::Result test_result("Testcase");
+ std::vector<uint8_t> vec1(5), vec2(5);
+ test_result.test_ne("test vectors not equal", vec1, vec2);
+ verify_failure("test vectors equal", result, test_result);
+ }
+
+ {
+ Test::Result test_result("Testcase");
+ std::vector<uint8_t> vec1(5), vec2(5);
+ test_result.test_ne("test arrays not equal", vec1.data(), vec1.size(), vec2.data(), vec2.size());
+ verify_failure("test vectors equal", result, test_result);
+ }
+
+ {
+ Test::Result test_result("Testcase");
size_t x = 5, y = 6;
test_result.test_eq("test ints equal", x, y);
verify_failure("test ints equal", result, test_result);
@@ -68,6 +86,13 @@ class Test_Tests final : public Test
{
Test::Result test_result("Testcase");
+ size_t x = 5, y = 5;
+ test_result.test_ne("test ints not equal", x, y);
+ verify_failure("test ints not equal", result, test_result);
+ }
+
+ {
+ Test::Result test_result("Testcase");
test_result.test_is_nonempty("empty", "");
verify_failure("test_is_nonempty", result, test_result);
}
@@ -128,6 +153,29 @@ class Test_Tests final : public Test
verify_failure("test_throws", result, test_result);
}
+ {
+ Test::Result test_result("Testcase");
+ test_result.test_throws("test_throws", "expected msg",
+ []() { ; });
+ verify_failure("test_throws", result, test_result);
+ }
+
+#if defined(BOTAN_HAS_BIGINT)
+ {
+ Test::Result test_result("Testcase");
+ Botan::BigInt x = 5, y = 6;
+ test_result.test_eq("test ints equal", x, y);
+ verify_failure("test ints equal", result, test_result);
+ }
+
+ {
+ Test::Result test_result("Testcase");
+ Botan::BigInt x = 5, y = 5;
+ test_result.test_ne("test ints not equal", x, y);
+ verify_failure("test ints not equal", result, test_result);
+ }
+#endif
+
return {result};
}
@@ -137,7 +185,13 @@ class Test_Tests final : public Test
const Test::Result& test_result)
{
if(test_result.tests_failed() > 0)
+ {
result.test_success("Got expected failure for " + what);
+ const std::string result_str = test_result.result_string(true);
+
+ result.confirm("result string contains FAIL",
+ result_str.find("FAIL") != std::string::npos);
+ }
else
result.test_failure("Expected test to fail for " + what);
}