X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=libtest%2Fcomparison.hpp;h=a04038b6c9ab0de7a86708f9f6cbcdc23568a889;hb=60c68bea5d034012f935eb849d92781c345c7214;hp=8656e49935447ba2a5e20d120a1ebe6a5eb286fe;hpb=ad94287c37250fcb1f7881705f0effb37bae7da5;p=awesomized%2Flibmemcached diff --git a/libtest/comparison.hpp b/libtest/comparison.hpp index 8656e499..a04038b6 100644 --- a/libtest/comparison.hpp +++ b/libtest/comparison.hpp @@ -22,13 +22,19 @@ #pragma once #include -#include + +#if defined(HAVE_LIBMEMCACHED) && HAVE_LIBMEMCACHED #include +#endif + +#if defined(HAVE_LIBGEARMAN) && HAVE_LIBGEARMAN +#include +#endif namespace libtest { template -bool _compare_true_hint(const char *file, int line, const char *func, T_comparable __expected, const char *assertation_label, T_hint __hint) +bool _compare_truth_hint(const char *file, int line, const char *func, T_comparable __expected, const char *assertation_label, T_hint __hint) { if (__expected == false) { @@ -40,24 +46,39 @@ bool _compare_true_hint(const char *file, int line, const char *func, T_comparab } template -bool _compare(const char *file, int line, const char *func, T_comparable __expected, T_comparable __actual) +bool _compare(const char *file, int line, const char *func, const T_comparable __expected, const T_comparable __actual) { if (__expected != __actual) { - if (typeid(__expected) == typeid(memcached_return_t)) + if (typeid(__expected) == typeid(test_return_t)) + { + const char *expected_str= test_strerror(test_return_t(__expected)); + const char *got_str= test_strerror(test_return_t(__actual)); + + libtest::stream::make_cerr(file, line, func) << "Expected \"" + << expected_str + << "\" got \"" + << got_str + << "\""; + } +#if defined(HAVE_LIBMEMCACHED) && HAVE_LIBMEMCACHED + else if (typeid(__expected) == typeid(memcached_return_t)) { libtest::stream::make_cerr(file, line, func) << "Expected \"" << memcached_strerror(NULL, memcached_return_t(__expected)) << "\" got \"" << memcached_strerror(NULL, memcached_return_t(__actual)) << "\""; } - else if (typeid(__expected) == typeid(test_return_t)) +#endif +#if defined(HAVE_LIBGEARMAN) && HAVE_LIBGEARMAN + else if (typeid(__expected) == typeid(gearman_return_t)) { libtest::stream::make_cerr(file, line, func) << "Expected \"" - << test_strerror(test_return_t(__expected)) + << gearman_strerror(gearman_return_t(__expected)) << "\" got \"" - << test_strerror(test_return_t(__actual)) << "\""; + << gearman_strerror(gearman_return_t(__actual)) << "\""; } +#endif else { libtest::stream::make_cerr(file, line, func) << "Expected \"" << __expected << "\" got \"" << __actual << "\""; @@ -80,13 +101,60 @@ bool _compare_zero(const char *file, int line, const char *func, T_comparable __ return true; } +template +bool _truth(const char *file, int line, const char *func, T_comparable __truth) +{ + if (bool(__truth)) + { + libtest::stream::make_cerr(file, line, func) << "Assertion failed for " << func << "() with \"" << __truth << "\""; + return false; + } + + return true; +} + template bool _compare_hint(const char *file, int line, const char *func, T_comparable __expected, T_comparable __actual, T_hint __hint) { if (__expected != __actual) { - libtest::stream::make_cerr(file, line, func) << "Expected \"" << __expected << "\" got \"" << __actual << "\" Additionally: \"" << __hint << "\""; + if (typeid(__expected) == typeid(test_return_t)) + { + const char *expected_str= test_strerror(test_return_t(__expected)); + const char *got_str= test_strerror(test_return_t(__actual)); + libtest::stream::make_cerr(file, line, func) << "Expected \"" + << expected_str + << "\" got \"" + << got_str + << "\"" + << " Additionally: \"" << __hint << "\""; + } +#if defined(HAVE_LIBMEMCACHED) && HAVE_LIBMEMCACHED + else if (typeid(__expected) == typeid(memcached_return_t)) + { + libtest::stream::make_cerr(file, line, func) << "Expected \"" + << memcached_strerror(NULL, memcached_return_t(__expected)) + << "\" got \"" + << memcached_strerror(NULL, memcached_return_t(__actual)) << "\"" + << " Additionally: \"" << __hint << "\""; + } +#endif +#if defined(HAVE_LIBGEARMAN) && HAVE_LIBGEARMAN + else if (typeid(__expected) == typeid(gearman_return_t)) + { + libtest::stream::make_cerr(file, line, func) << "Expected \"" + << gearman_strerror(gearman_return_t(__expected)) + << "\" got \"" + << gearman_strerror(gearman_return_t(__actual)) << "\"" + << " Additionally: \"" << __hint << "\""; + } +#endif + else + { + libtest::stream::make_cerr(file, line, func) << "Expected \"" << __expected << "\" got \"" << __actual << "\"" + << " Additionally: \"" << __hint << "\""; + } return false; }