Browse Source

The dots are there so you see test doing something. Therefore we should flush them after printing

svn:r1720
Peter Palfrader 21 years ago
parent
commit
750211259b
1 changed files with 17 additions and 16 deletions
  1. 17 16
      src/common/test.h

+ 17 - 16
src/common/test.h

@@ -6,6 +6,7 @@
 #define __TEST_H
 #define __TEST_H
 
 
 #include <string.h>
 #include <string.h>
+#include <stdio.h>
 
 
 #define STMT_BEGIN  do {
 #define STMT_BEGIN  do {
 #define STMT_END    } while (0)
 #define STMT_END    } while (0)
@@ -24,18 +25,18 @@ extern int have_failed;
     printf("\nFile %s: line %d (%s): assertion failed.",        \
     printf("\nFile %s: line %d (%s): assertion failed.",        \
       __FILE__,                                                 \
       __FILE__,                                                 \
       __LINE__,                                                 \
       __LINE__,                                                 \
-      PRETTY_FUNCTION);                                     \
+      PRETTY_FUNCTION);                                         \
     return;                                                     \
     return;                                                     \
   STMT_END
   STMT_END
 
 
 #define test_assert(expr)                                       \
 #define test_assert(expr)                                       \
   STMT_BEGIN                                                    \
   STMT_BEGIN                                                    \
-  if(expr) { printf("."); } else {                              \
+  if(expr) { printf("."); fflush(stdout); } else {              \
     have_failed = 1;                                            \
     have_failed = 1;                                            \
     printf("\nFile %s: line %d (%s): assertion failed: (%s)\n", \
     printf("\nFile %s: line %d (%s): assertion failed: (%s)\n", \
       __FILE__,                                                 \
       __FILE__,                                                 \
       __LINE__,                                                 \
       __LINE__,                                                 \
-      PRETTY_FUNCTION,                                      \
+      PRETTY_FUNCTION,                                          \
       #expr);                                                   \
       #expr);                                                   \
     return;                                                     \
     return;                                                     \
   } STMT_END
   } STMT_END
@@ -43,13 +44,13 @@ extern int have_failed;
 #define test_eq(expr1, expr2)                                   \
 #define test_eq(expr1, expr2)                                   \
   STMT_BEGIN                                                    \
   STMT_BEGIN                                                    \
     long v1=(long)(expr1), v2=(long)(expr2);                    \
     long v1=(long)(expr1), v2=(long)(expr2);                    \
-    if(v1==v2) { printf("."); } else {                          \
+    if(v1==v2) { printf("."); fflush(stdout); } else {          \
     have_failed = 1;                                            \
     have_failed = 1;                                            \
     printf("\nFile %s: line %d (%s): Assertion failed: (%s==%s)\n"\
     printf("\nFile %s: line %d (%s): Assertion failed: (%s==%s)\n"\
            "      (%ld != %ld)\n",                              \
            "      (%ld != %ld)\n",                              \
       __FILE__,                                                 \
       __FILE__,                                                 \
       __LINE__,                                                 \
       __LINE__,                                                 \
-      PRETTY_FUNCTION,                                      \
+      PRETTY_FUNCTION,                                          \
       #expr1, #expr2,                                           \
       #expr1, #expr2,                                           \
       v1, v2);                                                  \
       v1, v2);                                                  \
     return;                                                     \
     return;                                                     \
@@ -58,13 +59,13 @@ extern int have_failed;
 #define test_neq(expr1, expr2)                                  \
 #define test_neq(expr1, expr2)                                  \
   STMT_BEGIN                                                    \
   STMT_BEGIN                                                    \
     long v1=(long)(expr1), v2=(long)(expr2);                    \
     long v1=(long)(expr1), v2=(long)(expr2);                    \
-    if(v1!=v2) { printf("."); } else {                          \
+    if(v1!=v2) { printf("."); fflush(stdout); } else {          \
     have_failed = 1;                                            \
     have_failed = 1;                                            \
     printf("\nFile %s: line %d (%s): Assertion failed: (%s!=%s)\n"\
     printf("\nFile %s: line %d (%s): Assertion failed: (%s!=%s)\n"\
            "      (%ld == %ld)\n",                              \
            "      (%ld == %ld)\n",                              \
       __FILE__,                                                 \
       __FILE__,                                                 \
       __LINE__,                                                 \
       __LINE__,                                                 \
-      PRETTY_FUNCTION,                                      \
+      PRETTY_FUNCTION,                                          \
       #expr1, #expr2,                                           \
       #expr1, #expr2,                                           \
       v1, v2);                                                  \
       v1, v2);                                                  \
     return;                                                     \
     return;                                                     \
@@ -73,13 +74,13 @@ extern int have_failed;
 #define test_streq(expr1, expr2)                                \
 #define test_streq(expr1, expr2)                                \
   STMT_BEGIN                                                    \
   STMT_BEGIN                                                    \
     const char *v1=(expr1), *v2=(expr2);                        \
     const char *v1=(expr1), *v2=(expr2);                        \
-    if(!strcmp(v1,v2)) { printf("."); } else {                  \
+    if(!strcmp(v1,v2)) { printf("."); fflush(stdout); } else {  \
     have_failed = 1;                                            \
     have_failed = 1;                                            \
     printf("\nFile %s: line %d (%s): Assertion failed: (%s==%s)\n"\
     printf("\nFile %s: line %d (%s): Assertion failed: (%s==%s)\n"\
            "      (\"%s\" != \"%s\")\n",                        \
            "      (\"%s\" != \"%s\")\n",                        \
       __FILE__,                                                 \
       __FILE__,                                                 \
       __LINE__,                                                 \
       __LINE__,                                                 \
-      PRETTY_FUNCTION,                                      \
+      PRETTY_FUNCTION,                                          \
       #expr1, #expr2,                                           \
       #expr1, #expr2,                                           \
       v1, v2);                                                  \
       v1, v2);                                                  \
     return;                                                     \
     return;                                                     \
@@ -88,13 +89,13 @@ extern int have_failed;
 #define test_strneq(expr1, expr2)                               \
 #define test_strneq(expr1, expr2)                               \
   STMT_BEGIN                                                    \
   STMT_BEGIN                                                    \
     const char *v1=(expr1), *v2=(expr2);                        \
     const char *v1=(expr1), *v2=(expr2);                        \
-    if(strcmp(v1,v2)) { printf("."); } else {                   \
+    if(strcmp(v1,v2)) { printf("."); fflush(stdout); } else {   \
     have_failed = 1;                                            \
     have_failed = 1;                                            \
     printf("\nFile %s: line %d (%s): Assertion failed: (%s!=%s)\n"\
     printf("\nFile %s: line %d (%s): Assertion failed: (%s!=%s)\n"\
            "      (\"%s\" == \"%s\")\n",                        \
            "      (\"%s\" == \"%s\")\n",                        \
       __FILE__,                                                 \
       __FILE__,                                                 \
       __LINE__,                                                 \
       __LINE__,                                                 \
-      PRETTY_FUNCTION,                                      \
+      PRETTY_FUNCTION,                                          \
       #expr1, #expr2,                                           \
       #expr1, #expr2,                                           \
       v1, v2);                                                  \
       v1, v2);                                                  \
     return;                                                     \
     return;                                                     \
@@ -103,25 +104,25 @@ extern int have_failed;
 #define test_memeq(expr1, expr2, len)                           \
 #define test_memeq(expr1, expr2, len)                           \
   STMT_BEGIN                                                    \
   STMT_BEGIN                                                    \
     void *v1=(expr1), *v2=(expr2);                              \
     void *v1=(expr1), *v2=(expr2);                              \
-    if(!memcmp(v1,v2,(len))) { printf("."); } else {            \
+    if(!memcmp(v1,v2,(len))) { printf("."); fflush(stdout); } else {  \
     have_failed = 1;                                            \
     have_failed = 1;                                            \
     printf("\nFile %s: line %d (%s): Assertion failed: (%s==%s)\n", \
     printf("\nFile %s: line %d (%s): Assertion failed: (%s==%s)\n", \
       __FILE__,                                                 \
       __FILE__,                                                 \
       __LINE__,                                                 \
       __LINE__,                                                 \
-      PRETTY_FUNCTION,                                      \
+      PRETTY_FUNCTION,                                          \
       #expr1, #expr2);                                          \
       #expr1, #expr2);                                          \
     return;                                                     \
     return;                                                     \
   } STMT_END
   } STMT_END
 
 
-#define test_memneq(expr1, expr2, len)                           \
+#define test_memneq(expr1, expr2, len)                          \
   STMT_BEGIN                                                    \
   STMT_BEGIN                                                    \
     void *v1=(expr1), *v2=(expr2);                              \
     void *v1=(expr1), *v2=(expr2);                              \
-    if(memcmp(v1,v2,(len))) { printf("."); } else {             \
+    if(memcmp(v1,v2,(len))) { printf("."); fflush(stdout); } else {  \
     have_failed = 1;                                            \
     have_failed = 1;                                            \
     printf("\nFile %s: line %d (%s): Assertion failed: (%s!=%s)\n", \
     printf("\nFile %s: line %d (%s): Assertion failed: (%s!=%s)\n", \
       __FILE__,                                                 \
       __FILE__,                                                 \
       __LINE__,                                                 \
       __LINE__,                                                 \
-      PRETTY_FUNCTION,                                      \
+      PRETTY_FUNCTION,                                          \
       #expr1, #expr2);                                          \
       #expr1, #expr2);                                          \
     return;                                                     \
     return;                                                     \
   } STMT_END
   } STMT_END