X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=libtest%2Fcomparison.hpp;h=967e60689a2c175b4e5c6c136c8ba1d1651137ea;hb=7253c10fe79f6a72b0aec419560823a16ad55a0a;hp=8656e49935447ba2a5e20d120a1ebe6a5eb286fe;hpb=8fa241b9251e81929bd07410e9f598c88ee08242;p=m6w6%2Flibmemcached diff --git a/libtest/comparison.hpp b/libtest/comparison.hpp index 8656e499..967e6068 100644 --- a/libtest/comparison.hpp +++ b/libtest/comparison.hpp @@ -22,13 +22,29 @@ #pragma once #include -#include -#include + +#if defined(HAVE_LIBMEMCACHED) && HAVE_LIBMEMCACHED +#include +#include +#endif + +#if defined(HAVE_LIBGEARMAN) && HAVE_LIBGEARMAN +#include +#endif namespace libtest { +LIBTEST_API +bool gdb_is_caller(void); + +LIBTEST_API +bool valgrind_is_caller(void); + +LIBTEST_API +bool _in_valgrind(const char *file, int line, const char *func); + 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) { @@ -39,29 +55,16 @@ bool _compare_true_hint(const char *file, int line, const char *func, T_comparab return true; } -template -bool _compare(const char *file, int line, const char *func, T_comparable __expected, T_comparable __actual) +template +bool _compare(const char *file, int line, const char *func, const T1_comparable& __expected, const T2_comparable& __actual, bool use_io) { if (__expected != __actual) { - 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)) - { - libtest::stream::make_cerr(file, line, func) << "Expected \"" - << test_strerror(test_return_t(__expected)) - << "\" got \"" - << test_strerror(test_return_t(__actual)) << "\""; - } - else + if (use_io) { libtest::stream::make_cerr(file, line, func) << "Expected \"" << __expected << "\" got \"" << __actual << "\""; } + return false; } @@ -80,12 +83,43 @@ bool _compare_zero(const char *file, int line, const char *func, T_comparable __ return true; } -template -bool _compare_hint(const char *file, int line, const char *func, T_comparable __expected, T_comparable __actual, T_hint __hint) +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, T1_comparable __expected, T2_comparable __actual, T_hint __hint, bool io_error= true) { if (__expected != __actual) { - libtest::stream::make_cerr(file, line, func) << "Expected \"" << __expected << "\" got \"" << __actual << "\" Additionally: \"" << __hint << "\""; + if (io_error) + { + libtest::stream::make_cerr(file, line, func) << "Expected \"" << __expected << "\" got \"" << __actual << "\"" << " Additionally: \"" << __hint << "\""; + } + + return false; + } + + return true; +} + +template +bool _ne_compare_hint(const char *file, int line, const char *func, T1_comparable __expected, T2_comparable __actual, T_hint __hint, bool io_error= true) +{ + if (__expected == __actual) + { + if (io_error) + { + libtest::stream::make_cerr(file, line, func) << "Expected \"" << __expected << "\" got \"" << __actual << "\"" << " Additionally: \"" << __hint << "\""; + } return false; }