X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=libtest%2Flite.h;h=36f873e8be6649649e1da6db33003306f830b5bc;hb=61b948a92ab79734b009a438b5cf3bfad03cb59d;hp=56ea4c1774652fade9717f89addef1f5d5f74ca3;hpb=293e7b59e12ff6b95b5463614b09bc0158f14592;p=awesomized%2Flibmemcached diff --git a/libtest/lite.h b/libtest/lite.h index 56ea4c17..36f873e8 100644 --- a/libtest/lite.h +++ b/libtest/lite.h @@ -37,19 +37,25 @@ #pragma once #ifdef __cplusplus +# include # include +# include # include # include -#include #else +# include +# include # include +# include # include -# include # include -# include #endif -#include +#if defined(WIN32) +# include +#else +# include +#endif #ifndef __PRETTY_FUNCTION__ # define __PRETTY_FUNCTION__ __func__ @@ -64,18 +70,14 @@ #endif #ifndef FAIL -# define FAIL(__message_format, ...) +# define FAIL(__message_format, ...) #endif -static inline bool valgrind_is_caller(void) -{ - if (getenv("TESTS_ENVIRONMENT") && strstr(getenv("TESTS_ENVIRONMENT"), "valgrind")) - { - return true; - } +#ifndef SKIP +# define SKIP(__message_format, ...) +#endif - return false; -} +#include static inline size_t yatl_strlen(const char *s) { @@ -114,7 +116,54 @@ static inline int yatl_strcmp(const char *s1, const char *s2, size_t *s1_length, do \ { \ if ((__expression)) { \ - fprintf(stderr, "\n%s:%d: %s SKIP '!%s'\n", __FILE__, __LINE__, __PRETTY_FUNCTION__, #__expression); \ + if (YATL_FULL) { \ + SKIP(#__expression); \ + } \ + fprintf(stdout, "\n%s:%d: %s SKIP '!(%s)'\n", __FILE__, __LINE__, __PRETTY_FUNCTION__, #__expression); \ + exit(EXIT_SKIP); \ + } \ +} while (0) + +#define SKIP_IF_(__expression, ...) \ +do \ +{ \ + if ((__expression)) { \ + size_t ask= snprintf(0, 0, __VA_ARGS__); \ + ask++; \ + char *buffer= (char*)alloca(sizeof(char) * ask); \ + snprintf(buffer, ask, __VA_ARGS__); \ + if (YATL_FULL) { \ + SKIP(#__expression, buffer); \ + } \ + fprintf(stdout, "\n%s:%d: %s SKIP '%s' [ %s ]\n", __FILE__, __LINE__, __PRETTY_FUNCTION__, #__expression, buffer); \ + exit(EXIT_SKIP); \ + } \ +} while (0) + +#define SKIP_UNLESS(__expression) \ +do \ +{ \ + if (! (__expression)) { \ + if (YATL_FULL) { \ + SKIP(#__expression); \ + } \ + fprintf(stdout, "\n%s:%d: %s SKIP '(%s)'\n", __FILE__, __LINE__, __PRETTY_FUNCTION__, #__expression); \ + exit(EXIT_SKIP); \ + } \ +} while (0) + +#define SKIP_UNLESS_(__expression, ...) \ +do \ +{ \ + if (! (__expression)) { \ + size_t ask= snprintf(0, 0, __VA_ARGS__); \ + ask++; \ + char *buffer= (char*)alloca(sizeof(char) * ask); \ + snprintf(buffer, ask, __VA_ARGS__); \ + if (YATL_FULL) { \ + SKIP(#__expression, buffer); \ + } \ + fprintf(stdout, "\n%s:%d: %s SKIP '%s' [ %s ]\n", __FILE__, __LINE__, __PRETTY_FUNCTION__, #__expression, buffer); \ exit(EXIT_SKIP); \ } \ } while (0) @@ -149,10 +198,12 @@ do \ if ((__expression) != NULL) { \ size_t ask= snprintf(0, 0, __VA_ARGS__); \ ask++; \ - char *buffer= (char*)malloc(sizeof(char) * ask); \ + char *buffer= (char*)alloca(sizeof(char) * ask); \ snprintf(buffer, ask, __VA_ARGS__); \ + if (YATL_FULL) { \ + FAIL("Assertion '%s' != NULL [ %s ]", #__expression, buffer);\ + } \ fprintf(stderr, "\n%s:%d: %s Assertion '%s' != NULL [ %s ]\n", __FILE__, __LINE__, __PRETTY_FUNCTION__, #__expression, buffer);\ - free(buffer); \ exit(EXIT_FAILURE); \ } \ } while (0) @@ -161,6 +212,9 @@ do \ do \ { \ if ((__expression) == NULL) { \ + if (YATL_FULL) { \ + FAIL("Assertion '%s' == NULL", #__expression,);\ + } \ fprintf(stderr, "\n%s:%d: %s Assertion '%s' == NULL\n", __FILE__, __LINE__, __PRETTY_FUNCTION__, #__expression,);\ exit(EXIT_FAILURE); \ } \ @@ -172,38 +226,28 @@ do \ if ((__expression) == NULL) { \ size_t ask= snprintf(0, 0, __VA_ARGS__); \ ask++; \ - char *buffer= (char*)malloc(sizeof(char) * ask); \ + char *buffer= (char*)alloca(sizeof(char) * ask); \ snprintf(buffer, ask, __VA_ARGS__); \ + if (YATL_FULL) { \ + FAIL("Assertion '%s' == NULL [ %s ]", #__expression, buffer);\ + } \ fprintf(stderr, "\n%s:%d: %s Assertion '%s' == NULL [ %s ]\n", __FILE__, __LINE__, __PRETTY_FUNCTION__, #__expression, buffer);\ - free(buffer); \ exit(EXIT_FAILURE); \ } \ } while (0) -#define SKIP_IF_(__expression, ...) \ -do \ -{ \ - if ((__expression)) { \ - size_t ask= snprintf(0, 0, __VA_ARGS__); \ - ask++; \ - char *buffer= (char*)malloc(sizeof(char) * ask); \ - snprintf(buffer, ask, __VA_ARGS__); \ - fprintf(stdout, "\n%s:%d: %s SKIP '%s' [ %s ]\n", __FILE__, __LINE__, __PRETTY_FUNCTION__, #__expression, buffer); \ - free(buffer); \ - exit(EXIT_SKIP); \ - } \ -} while (0) - #define ASSERT_TRUE_(__expression, ...) \ do \ { \ if (! (__expression)) { \ size_t ask= snprintf(0, 0, __VA_ARGS__); \ ask++; \ - char *buffer= (char*)malloc(sizeof(char) * ask); \ + char *buffer= (char*)alloca(sizeof(char) * ask); \ snprintf(buffer, ask, __VA_ARGS__); \ + if (YATL_FULL) { \ + FAIL("Assertion '%s' [ %s ]", #__expression, buffer); \ + } \ fprintf(stderr, "\n%s:%d: %s Assertion '%s' [ %s ]\n", __FILE__, __LINE__, __PRETTY_FUNCTION__, #__expression, buffer); \ - free(buffer); \ exit(EXIT_FAILURE); \ } \ } while (0) @@ -212,6 +256,9 @@ do \ do \ { \ if ((__expected) != (__actual)) { \ + if (YATL_FULL) { \ + FAIL("Assertion '%s' != '%s'", #__expected, #__actual); \ + } \ fprintf(stderr, "\n%s:%d: %s Assertion '%s' != '%s'\n", __FILE__, __LINE__, __PRETTY_FUNCTION__, #__expected, #__actual); \ exit(EXIT_FAILURE); \ } \ @@ -223,10 +270,12 @@ do \ if ((__expected) != (__actual)) { \ size_t ask= snprintf(0, 0, __VA_ARGS__); \ ask++; \ - char *buffer= (char*)malloc(sizeof(char) * ask); \ + char *buffer= (char*)alloca(sizeof(char) * ask); \ snprintf(buffer, ask, __VA_ARGS__); \ + if (YATL_FULL) { \ + FAIL("Assertion '%s' != '%s' [ %s ]", #__expected, #__actual, buffer); \ + } \ fprintf(stderr, "\n%s:%d: %s Assertion '%s' != '%s' [ %s ]\n", __FILE__, __LINE__, __PRETTY_FUNCTION__, #__expected, #__actual, buffer); \ - free(buffer); \ exit(EXIT_FAILURE); \ } \ } while (0) @@ -238,6 +287,11 @@ do \ size_t __actual_length; \ int ret= yatl_strcmp(__expected_str, __actual_str, &__expected_length, &__actual_length); \ if (ret) { \ + if (YATL_FULL) { \ + FAIL("Assertion '%.*s' != '%.*s'\n", \ + (int)(__expected_length), (__expected_str), \ + (int)__actual_length, (__actual_str)) ; \ + } \ fprintf(stderr, "\n%s:%d: %s Assertion '%.*s' != '%.*s'\n", __FILE__, __LINE__, __PRETTY_FUNCTION__, \ (int)(__expected_length), (__expected_str), \ (int)__actual_length, (__actual_str)) ; \ @@ -254,13 +308,18 @@ do \ if (ret) { \ size_t ask= snprintf(0, 0, __VA_ARGS__); \ ask++; \ - char *buffer= (char*)malloc(sizeof(char) * ask); \ + char *buffer= (char*)alloca(sizeof(char) * ask); \ ask= snprintf(buffer, ask, __VA_ARGS__); \ + if (YATL_FULL) { \ + FAIL("Assertion '%.*s' != '%.*s' [ %.*s ]", \ + (int)(__expected_length), (__expected_str), \ + (int)(__actual_length), (__actual_str), \ + (int)(ask), buffer); \ + } \ fprintf(stderr, "\n%s:%d: %s Assertion '%.*s' != '%.*s' [ %.*s ]\n", __FILE__, __LINE__, __PRETTY_FUNCTION__, \ (int)(__expected_length), (__expected_str), \ (int)(__actual_length), (__actual_str), \ (int)(ask), buffer); \ - free(buffer); \ exit(EXIT_FAILURE); \ } \ } while (0) @@ -272,6 +331,11 @@ do \ size_t __actual_length; \ int ret= yatl_strcmp(__expected_str, __actual_str, &__expected_length, &__actual_length); \ if (ret == 0) { \ + if (YATL_FULL) { \ + FAIL("Assertion '%.*s' == '%.*s'", \ + (int)(__expected_length), (__expected_str), \ + (int)__actual_length, (__actual_str)) ; \ + } \ fprintf(stderr, "\n%s:%d: %s Assertion '%.*s' == '%.*s'\n", __FILE__, __LINE__, __PRETTY_FUNCTION__, \ (int)(__expected_length), (__expected_str), \ (int)__actual_length, (__actual_str)) ; \ @@ -288,21 +352,29 @@ do \ if (ret == 0) { \ size_t ask= snprintf(0, 0, __VA_ARGS__); \ ask++; \ - char *buffer= (char*)malloc(sizeof(char) * ask); \ + char *buffer= (char*)alloca(sizeof(char) * ask); \ ask= snprintf(buffer, ask, __VA_ARGS__); \ + if (YATL_FULL) { \ + FAIL("Assertion '%.*s' == '%.*s' [ %.*s ]", \ + (int)(__expected_length), (__expected_str), \ + (int)(__actual_length), (__actual_str), \ + (int)(ask), buffer); \ + } \ fprintf(stderr, "\n%s:%d: %s Assertion '%.*s' == '%.*s' [ %.*s ]\n", __FILE__, __LINE__, __PRETTY_FUNCTION__, \ (int)(__expected_length), (__expected_str), \ (int)(__actual_length), (__actual_str), \ (int)(ask), buffer); \ - free(buffer); \ exit(EXIT_FAILURE); \ } \ } while (0) -#define ASSERT_NEQ(__expected, __actual, ...) \ +#define ASSERT_NEQ(__expected, __actual) \ do \ { \ if ((__expected) == (__actual)) { \ + if (YATL_FULL) { \ + FAIL("Assertion '%s' == '%s'", #__expected, #__actual); \ + } \ fprintf(stderr, "\n%s:%d: %s Assertion '%s' == '%s'\n", __FILE__, __LINE__, __PRETTY_FUNCTION__, #__expected, #__actual); \ exit(EXIT_FAILURE); \ } \ @@ -314,10 +386,12 @@ do \ if ((__expected) == (__actual)) { \ size_t ask= snprintf(0, 0, __VA_ARGS__); \ ask++; \ - char *buffer= (char*)malloc(sizeof(char) * ask); \ + char *buffer= (char*)alloca(sizeof(char) * ask); \ snprintf(buffer, ask, __VA_ARGS__); \ + if (YATL_FULL) { \ + FAIL("Assertion '%s' == '%s' [ %s ]", #__expected, #__actual, buffer); \ + } \ fprintf(stderr, "\n%s:%d: %s Assertion '%s' == '%s' [ %s ]\n", __FILE__, __LINE__, __PRETTY_FUNCTION__, #__expected, #__actual, buffer); \ - free(buffer); \ exit(EXIT_FAILURE); \ } \ } while (0) @@ -331,7 +405,7 @@ do \ char *buffer= (char*)alloca(sizeof(char) * ask); \ snprintf(buffer, ask, __VA_ARGS__); \ if (YATL_FULL) { \ - throw libtest::__failure(__FILE__, __LINE__, __PRETTY_FUNCTION__, "Assertion '!%s' [ %s ]", #__expression, buffer); \ + FAIL("Assertion '!%s' [ %s ]", #__expression, buffer); \ } \ fprintf(stderr, "\n%s:%d: %s Assertion '!%s' [ %s ]\n", __FILE__, __LINE__, __PRETTY_FUNCTION__, #__expression, buffer); \ exit(EXIT_FAILURE); \