aboutsummaryrefslogtreecommitdiffstats
path: root/camel/tests/lib
diff options
context:
space:
mode:
authorNot Zed <NotZed@HelixCode.com>2000-11-24 11:54:55 +0800
committerMichael Zucci <zucchi@src.gnome.org>2000-11-24 11:54:55 +0800
commit189cb50426fc12b55a79c67a00064623ec964383 (patch)
treecdc37cf4d65c4b5a7fb69de104663be4875d0781 /camel/tests/lib
parent99e80d6ecf06cc60f2734f87bc974bd9479ba139 (diff)
downloadgsoc2013-evolution-189cb50426fc12b55a79c67a00064623ec964383.tar
gsoc2013-evolution-189cb50426fc12b55a79c67a00064623ec964383.tar.gz
gsoc2013-evolution-189cb50426fc12b55a79c67a00064623ec964383.tar.bz2
gsoc2013-evolution-189cb50426fc12b55a79c67a00064623ec964383.tar.lz
gsoc2013-evolution-189cb50426fc12b55a79c67a00064623ec964383.tar.xz
gsoc2013-evolution-189cb50426fc12b55a79c67a00064623ec964383.tar.zst
gsoc2013-evolution-189cb50426fc12b55a79c67a00064623ec964383.zip
Added at least some explanation of all this stuff.
2000-11-24 Not Zed <NotZed@HelixCode.com> * tests/README: Added at least some explanation of all this stuff. * tests/lib/camel-test.h (check_msg): Added a non-gcc version of the fail command, we dont get the expression that failed, but no matter. Should be (more) portable now. (check, check_msg): Put the file/lineno in the default message. svn path=/trunk/; revision=6657
Diffstat (limited to 'camel/tests/lib')
-rw-r--r--camel/tests/lib/camel-test.c20
-rw-r--r--camel/tests/lib/camel-test.h24
2 files changed, 32 insertions, 12 deletions
diff --git a/camel/tests/lib/camel-test.c b/camel/tests/lib/camel-test.c
index b60ba1fb34..a913ad78a4 100644
--- a/camel/tests/lib/camel-test.c
+++ b/camel/tests/lib/camel-test.c
@@ -18,7 +18,7 @@ int camel_test_verbose;
static void die(int sig)
{
- static indie = 0;
+ static int indie = 0;
struct _stack *node;
if (!indie) {
@@ -118,17 +118,23 @@ void camel_test_pull(void)
void camel_test_fail(const char *why, ...)
{
- struct _stack *node;
va_list ap;
- char *text;
va_start(ap, why);
- text = g_strdup_vprintf(why, ap);
+ camel_test_failv(why, ap);
va_end(ap);
+}
+
+void camel_test_failv(const char *why, va_list ap)
+{
+ struct _stack *node;
+ char *text;
+
+ text = g_strdup_vprintf(why, ap);
if ((nonfatal == NULL && camel_test_verbose > 0)
|| (nonfatal && camel_test_verbose > 1)) {
- printf("Failed: %s\n", text);
+ printf("Failed.\n%s\n", text);
}
g_free(text);
@@ -174,8 +180,7 @@ void camel_test_nonfatal(const char *why, ...)
nonfatal = node;
}
-/* dont ask me why but the compiler just can't seem to find the prototypes for this */
-void camel_test_fatal()
+void camel_test_fatal(void)
{
struct _stack *node;
@@ -209,7 +214,6 @@ void camel_test_end(void)
int string_equal(const char *a, const char *b)
{
const char *ap, *bp;
- int cmp;
ap = a;
bp = b;
diff --git a/camel/tests/lib/camel-test.h b/camel/tests/lib/camel-test.h
index 8d3c94bd00..6ff8281aeb 100644
--- a/camel/tests/lib/camel-test.h
+++ b/camel/tests/lib/camel-test.h
@@ -6,9 +6,25 @@
#include <stdlib.h>
#include <glib.h>
+void camel_test_failv(const char *why, va_list ap);
+
/* perform a check assertion */
-#define check(x) do {if (!(x)) { camel_test_fail("%s", #x); } } while (0)
-#define check_msg(x, y, z...) do {if (!(x)) { camel_test_fail("%s\n\t" #y, #x, ##z); } } while (0)
+#define check(x) do {if (!(x)) { camel_test_fail("%s (%d): %s", __FILE__, __LINE__, #x); } } while (0)
+/* check with message */
+#ifdef __GNUC__
+#define check_msg(x, y, z...) do {if (!(x)) { camel_test_fail("%s (%d): %s\n\t" #y, __FILE__, __LINE__, #x, ##z); } } while (0)
+#else
+static void check_msg(int truth, char *fmt, ...)
+{
+ /* no gcc, we lose the condition that failed, nm */
+ if (!truth) {
+ va_list ap;
+ va_start(ap, fmt);
+ camel_test_failv(fmt, ap);
+ va_end(ap);
+ }
+}
+#endif
#define check_count(object, expected) do { \
if (CAMEL_OBJECT(object)->ref_count != expected) { \
@@ -41,11 +57,11 @@ void camel_test_pull(void);
/* fail a test, with a reason why */
void camel_test_fail(const char *why, ...);
+void camel_test_failv(const char *why, va_list ap);
/* Set whether a failed test quits. May be nested, but must be called in nonfatal/fatal pairs */
void camel_test_nonfatal(const char *why, ...);
-void camel_test_fatal();
-
+void camel_test_fatal(void);
/* utility functions */
/* compare strings, ignore whitespace though */