major refactoring of test framework

2012-05-31

author
Mike Becker <universe@uap-core.de>
date
Thu, 31 May 2012 12:51:22 +0200 (2012-05-31)
changeset 33
9c219a62070d
parent 32
c7af4ec56e19
child 34
0dcd2ca2a223

major refactoring of test framework

test/dlist_tests.c file | annotate | diff | comparison | revisions
test/list_tests.c file | annotate | diff | comparison | revisions
test/main.c file | annotate | diff | comparison | revisions
test/map_tests.c file | annotate | diff | comparison | revisions
test/map_tests.h file | annotate | diff | comparison | revisions
test/mpool_tests.c file | annotate | diff | comparison | revisions
ucx/test.h file | annotate | diff | comparison | revisions
--- a/test/dlist_tests.c	Thu May 31 09:18:26 2012 +0200
+++ b/test/dlist_tests.c	Thu May 31 12:51:22 2012 +0200
@@ -4,8 +4,9 @@
 
 #include "dlist_tests.h"
 
-UCX_TEST_BEGIN(test_ucx_dlist_append) {
+UCX_TEST_IMPLEMENT(test_ucx_dlist_append) {
     UcxDlist *list = ucx_dlist_append(NULL, "Hello");
+    UCX_TEST_BEGIN
     
     UCX_TEST_ASSERT(strncmp(list->data, "Hello", 5) == 0, "failed")
     
@@ -13,46 +14,47 @@
     
     UCX_TEST_ASSERT(strncmp(list->next->data, " World!", 7) == 0, "failed")
     UCX_TEST_ASSERT(list->next->next == NULL, "failed")
+    UCX_TEST_END
     
     ucx_dlist_free(list);
-    
-    UCX_TEST_END
 }
 
-UCX_TEST_BEGIN(test_ucx_dlist_prepend) {
+UCX_TEST_IMPLEMENT(test_ucx_dlist_prepend) {
     UcxDlist *list = ucx_dlist_prepend(NULL, " World!");
+    UCX_TEST_BEGIN
+
     list = ucx_dlist_prepend(list, "Hello");
     
     UCX_TEST_ASSERT(strncmp(list->data, "Hello", 5) == 0, "failed")
     UCX_TEST_ASSERT(strncmp(list->next->data, " World!", 7) == 0, "failed")
     UCX_TEST_ASSERT(list->next->next == NULL, "failed")
     
+    UCX_TEST_END
     ucx_dlist_free(list);
-    
-    UCX_TEST_END
 }
 
-UCX_TEST_BEGIN(test_ucx_dlist_equals) {
+UCX_TEST_IMPLEMENT(test_ucx_dlist_equals) {
     UcxDlist *list = ucx_dlist_append(NULL, "Hello");
     list = ucx_dlist_append(list, " World!");
     UcxDlist *list2 = ucx_dlist_prepend(NULL, " World!");
     list2 = ucx_dlist_prepend(list2, "Hello");
     UcxDlist *list3 = ucx_dlist_prepend(NULL, " Welt!");
     list3 = ucx_dlist_prepend(list3, "Hallo");
+    UCX_TEST_BEGIN
     
     UCX_TEST_ASSERT(ucx_dlist_equals(list, list2, cmp_string, NULL), "failed")
     UCX_TEST_ASSERT(!ucx_dlist_equals(list, list3, cmp_string, NULL), "failed")
     
+    UCX_TEST_END
     ucx_dlist_free(list3);
     ucx_dlist_free(list2);
     ucx_dlist_free(list);
-    
-    UCX_TEST_END
 }
 
-UCX_TEST_BEGIN(test_ucx_dlist_concat) {
+UCX_TEST_IMPLEMENT(test_ucx_dlist_concat) {
     UcxDlist *list = ucx_dlist_append(NULL, "Hello");
     UcxDlist *list2 = ucx_dlist_prepend(NULL, " World!");
+    UCX_TEST_BEGIN
     
     list = ucx_dlist_concat(list, list2);
     
@@ -60,13 +62,13 @@
     UCX_TEST_ASSERT(strncmp(list->next->data, " World!", 7) == 0, "failed")
     UCX_TEST_ASSERT(list->next->next == NULL, "failed")
     
+    UCX_TEST_END
     ucx_dlist_free(list);
-    
-    UCX_TEST_END
 }
 
-UCX_TEST_BEGIN(test_ucx_dlist_size) {
+UCX_TEST_IMPLEMENT(test_ucx_dlist_size) {
     UcxDlist *list = ucx_dlist_append(NULL, "This ");
+    UCX_TEST_BEGIN
     list = ucx_dlist_append(list, "list ");
     list = ucx_dlist_append(list, "has ");
     list = ucx_dlist_append(list, "size ");
@@ -74,13 +76,13 @@
     
     UCX_TEST_ASSERT(ucx_dlist_size(list) == 5, "failed");
     
+    UCX_TEST_END
     ucx_dlist_free(list);
-    
-    UCX_TEST_END
 }
 
-UCX_TEST_BEGIN(test_ucx_dlist_first) {
+UCX_TEST_IMPLEMENT(test_ucx_dlist_first) {
     UcxDlist *list = ucx_dlist_append(NULL, "Find ");
+    UCX_TEST_BEGIN
     list = ucx_dlist_append(list, "the ");
     list = ucx_dlist_append(list, "first!");
     
@@ -88,13 +90,13 @@
     
     UCX_TEST_ASSERT(strncmp(first, "Find ", 5) == 0, "failed");
     
+    UCX_TEST_END
     ucx_dlist_free(list);
-    
-    UCX_TEST_END
 }
 
-UCX_TEST_BEGIN(test_ucx_dlist_last) {
+UCX_TEST_IMPLEMENT(test_ucx_dlist_last) {
     UcxDlist *list = ucx_dlist_append(NULL, "Find ");
+    UCX_TEST_BEGIN
     list = ucx_dlist_append(list, "the ");
     list = ucx_dlist_append(list, "last!");
     
@@ -102,13 +104,13 @@
     
     UCX_TEST_ASSERT(strncmp(last, "last!", 5) == 0, "failed");
     
+    UCX_TEST_END
     ucx_dlist_free(list);
-    
-    UCX_TEST_END
 }
 
-UCX_TEST_BEGIN(test_ucx_dlist_get) {
+UCX_TEST_IMPLEMENT(test_ucx_dlist_get) {
     UcxDlist *list = ucx_dlist_append(NULL, "Find ");
+    UCX_TEST_BEGIN
     list = ucx_dlist_append(list, "the ");
     list = ucx_dlist_append(list, "mid!");
     
@@ -116,13 +118,13 @@
     
     UCX_TEST_ASSERT(strncmp(mid, "the ", 4) == 0, "failed");
     
+    UCX_TEST_END
     ucx_dlist_free(list);
-    
-    UCX_TEST_END
 }
 
-UCX_TEST_BEGIN(test_ucx_dlist_remove) {
+UCX_TEST_IMPLEMENT(test_ucx_dlist_remove) {
     UcxDlist *list = ucx_dlist_append(NULL, "Hello");
+    UCX_TEST_BEGIN
     list = ucx_dlist_append(list, " fucking");
     list = ucx_dlist_append(list, " World!");
     
@@ -132,12 +134,11 @@
     UCX_TEST_ASSERT(strncmp(list->next->data, " World!", 7) == 0, "failed")
     UCX_TEST_ASSERT(list->next->next == NULL, "failed")
     
+    UCX_TEST_END
     ucx_dlist_free(list);
-    
-    UCX_TEST_END
 }
 
-UCX_TEST_BEGIN(test_ucx_dlist_clone) {
+UCX_TEST_IMPLEMENT(test_ucx_dlist_clone) {
    
     char *hello = (char*)malloc(6);
     char *world = (char*)malloc(8);
@@ -149,11 +150,13 @@
     list = ucx_dlist_append(list, world);
     
     UcxDlist *copy = ucx_dlist_clone(list, copy_string, NULL);
+    UCX_TEST_BEGIN
 
     UCX_TEST_ASSERT(ucx_dlist_equals(list, copy, cmp_string, NULL), "failed")
     UCX_TEST_ASSERT(hello != copy->data, "first element is no copy")
     UCX_TEST_ASSERT(world != copy->next->data, "second element is no copy")
 
+    UCX_TEST_END
     free(copy->next->data);
     free(copy->data);
 
@@ -161,6 +164,4 @@
     free(hello);
     ucx_dlist_free(list);
     ucx_dlist_free(copy);
-    
-    UCX_TEST_END
 }
--- a/test/list_tests.c	Thu May 31 09:18:26 2012 +0200
+++ b/test/list_tests.c	Thu May 31 12:51:22 2012 +0200
@@ -4,35 +4,34 @@
 
 #include "list_tests.h"
 
-UCX_TEST_BEGIN(test_ucx_list_append) {
+UCX_TEST_IMPLEMENT(test_ucx_list_append) {
     UcxList *list = ucx_list_append(NULL, "Hello");
-    
+    UCX_TEST_BEGIN
     UCX_TEST_ASSERT(strncmp(list->data, "Hello", 5) == 0, "failed")
     
     list = ucx_list_append(list, " World!");
     
     UCX_TEST_ASSERT(strncmp(list->next->data, " World!", 7) == 0, "failed")
     UCX_TEST_ASSERT(list->next->next == NULL, "failed")
-    
+
+    UCX_TEST_END
     ucx_list_free(list);
-    
-    UCX_TEST_END
 }
 
-UCX_TEST_BEGIN(test_ucx_list_prepend) {
+UCX_TEST_IMPLEMENT(test_ucx_list_prepend) {
     UcxList *list = ucx_list_prepend(NULL, " World!");
+    UCX_TEST_BEGIN
     list = ucx_list_prepend(list, "Hello");
     
     UCX_TEST_ASSERT(strncmp(list->data, "Hello", 5) == 0, "failed")
     UCX_TEST_ASSERT(strncmp(list->next->data, " World!", 7) == 0, "failed")
     UCX_TEST_ASSERT(list->next->next == NULL, "failed")
     
+    UCX_TEST_END
     ucx_list_free(list);
-    
-    UCX_TEST_END
 }
 
-UCX_TEST_BEGIN(test_ucx_list_equals) {
+UCX_TEST_IMPLEMENT(test_ucx_list_equals) {
     UcxList *list = ucx_list_append(NULL, "Hello");
     list = ucx_list_append(list, " World!");
     UcxList *list2 = ucx_list_prepend(NULL, " World!");
@@ -40,33 +39,37 @@
     UcxList *list3 = ucx_list_prepend(NULL, " Welt!");
     list3 = ucx_list_prepend(list3, "Hallo");
     
+    UCX_TEST_BEGIN
     UCX_TEST_ASSERT(ucx_list_equals(list, list2, cmp_string, NULL), "failed")
     UCX_TEST_ASSERT(!ucx_list_equals(list, list3, cmp_string, NULL), "failed")
+    UCX_TEST_END
     
     ucx_list_free(list3);
     ucx_list_free(list2);
     ucx_list_free(list);
-    
-    UCX_TEST_END
 }
 
-UCX_TEST_BEGIN(test_ucx_list_concat) {
+UCX_TEST_IMPLEMENT(test_ucx_list_concat) {
     UcxList *list = ucx_list_append(NULL, "Hello");
     UcxList *list2 = ucx_list_prepend(NULL, " World!");
     
     list = ucx_list_concat(list, list2);
+    UCX_TEST_BEGIN
     
     UCX_TEST_ASSERT(strncmp(list->data, "Hello", 5) == 0, "failed")
     UCX_TEST_ASSERT(strncmp(list->next->data, " World!", 7) == 0, "failed")
     UCX_TEST_ASSERT(list->next->next == NULL, "failed")
     
+    UCX_TEST_END
+    if (list->next == NULL) {
+        ucx_list_free(list2);
+    }
     ucx_list_free(list);
-    
-    UCX_TEST_END
 }
 
-UCX_TEST_BEGIN(test_ucx_list_size) {
+UCX_TEST_IMPLEMENT(test_ucx_list_size) {
     UcxList *list = ucx_list_append(NULL, "This ");
+    UCX_TEST_BEGIN
     list = ucx_list_append(list, "list ");
     list = ucx_list_append(list, "has ");
     list = ucx_list_append(list, "size ");
@@ -74,13 +77,13 @@
     
     UCX_TEST_ASSERT(ucx_list_size(list) == 5, "failed");
     
+    UCX_TEST_END
     ucx_list_free(list);
-    
-    UCX_TEST_END
 }
 
-UCX_TEST_BEGIN(test_ucx_list_last) {
+UCX_TEST_IMPLEMENT(test_ucx_list_last) {
     UcxList *list = ucx_list_append(NULL, "Find ");
+    UCX_TEST_BEGIN
     list = ucx_list_append(list, "the ");
     list = ucx_list_append(list, "last!");
     
@@ -88,13 +91,14 @@
     
     UCX_TEST_ASSERT(strncmp(last, "last!", 5) == 0, "failed");
     
+    UCX_TEST_END
     ucx_list_free(list);
     
-    UCX_TEST_END
 }
 
-UCX_TEST_BEGIN(test_ucx_list_get) {
+UCX_TEST_IMPLEMENT(test_ucx_list_get) {
     UcxList *list = ucx_list_append(NULL, "Find ");
+    UCX_TEST_BEGIN
     list = ucx_list_append(list, "the ");
     list = ucx_list_append(list, "mid!");
     
@@ -102,13 +106,13 @@
     
     UCX_TEST_ASSERT(strncmp(mid, "the ", 4) == 0, "failed");
     
+    UCX_TEST_END
     ucx_list_free(list);
-    
-    UCX_TEST_END
 }
 
-UCX_TEST_BEGIN(test_ucx_list_remove) {
+UCX_TEST_IMPLEMENT(test_ucx_list_remove) {
     UcxList *list = ucx_list_append(NULL, "Hello");
+    UCX_TEST_BEGIN
     list = ucx_list_append(list, " fucking");
     list = ucx_list_append(list, " World!");
     
@@ -117,13 +121,12 @@
     UCX_TEST_ASSERT(strncmp(list->data, "Hello", 5) == 0, "failed")
     UCX_TEST_ASSERT(strncmp(list->next->data, " World!", 7) == 0, "failed")
     UCX_TEST_ASSERT(list->next->next == NULL, "failed")
+    UCX_TEST_END
     
     ucx_list_free(list);
-    
-    UCX_TEST_END
 }
 
-UCX_TEST_BEGIN(test_ucx_list_clone) {
+UCX_TEST_IMPLEMENT(test_ucx_list_clone) {
    
     char *hello = (char*)malloc(6);
     char *world = (char*)malloc(8);
@@ -135,11 +138,13 @@
     list = ucx_list_append(list, world);
     
     UcxList *copy = ucx_list_clone(list, copy_string, NULL);
+    UCX_TEST_BEGIN
 
     UCX_TEST_ASSERT(ucx_list_equals(list, copy, cmp_string, NULL), "failed")
     UCX_TEST_ASSERT(hello != copy->data, "first element is no copy")
     UCX_TEST_ASSERT(world != copy->next->data, "second element is no copy")
-            
+
+    UCX_TEST_END
     free(copy->next->data);
     free(copy->data);
 
@@ -147,6 +152,4 @@
     free(hello);
     ucx_list_free(list);
     ucx_list_free(copy);
-    
-    UCX_TEST_END
 }
--- a/test/main.c	Thu May 31 09:18:26 2012 +0200
+++ b/test/main.c	Thu May 31 12:51:22 2012 +0200
@@ -51,25 +51,57 @@
     return cpy;
 }
 
-UCX_TEST_BEGIN(testTestSuitePositive) {
+UCX_TEST_IMPLEMENT(testTestSuitePositive) {
+    UCX_TEST_BEGIN
     UCX_TEST_ASSERT(2*2 == 4, "the test framework fails")
     UCX_TEST_END
 }
 
-UCX_TEST_BEGIN(testTestSuiteNegative) {
+UCX_TEST_IMPLEMENT(testTestSuiteNegative) {
+    UCX_TEST_BEGIN
     UCX_TEST_ASSERT(2*(-2) == 4, "the test framework works")
     UCX_TEST_END
 }
 
+UCX_TEST_SUBROUTINE(testTestSuiteRoutineSuccess,field) {
+    int* i = (int*) field;
+    *i += 2;
+    UCX_TEST_ASSERT(*i==4, "the test framework fails");
+}
+
+UCX_TEST_SUBROUTINE(testTestSuiteRoutineFailure,field) {
+    int* i = (int*) field;
+    *i += 2;
+    UCX_TEST_ASSERT(*i==4, "the test framework works");
+}
+
+UCX_TEST_IMPLEMENT(testTestSuiteRoutinePositive) {
+    int i = 2;
+    UCX_TEST_BEGIN
+    UCX_TEST_CALL_SUBROUTINE(testTestSuiteRoutineSuccess, &i);
+    UCX_TEST_ASSERT(i==4, "the test framework fails");
+    UCX_TEST_END
+}
+
+UCX_TEST_IMPLEMENT(testTestSuiteRoutineNegative) {
+    int i = 0;
+    UCX_TEST_BEGIN
+    UCX_TEST_CALL_SUBROUTINE(testTestSuiteRoutineFailure, &i);
+    UCX_TEST_ASSERT(1, "the test framework fails");
+    UCX_TEST_END
+}
+
 int main(int argc, char **argv) {
     printf("UCX Tests\n---------\n");
 
-    printf("\nUcxTestSuite tests (1 failure is intended!)\n");
+    printf("\nUcxTestSuite tests (2 failures are intended!)\n");
     UcxTestSuite* suite = ucx_test_suite_new();
     ucx_test_register(suite, testTestSuitePositive);
     ucx_test_register(suite, testTestSuiteNegative);
+    ucx_test_register(suite, testTestSuiteRoutinePositive);
+    ucx_test_register(suite, testTestSuiteRoutineNegative);
     ucx_test_run(suite, stdout);
-    if (suite->failure == 1 && suite->success == 1) {
+    if (suite->failure == 2 && suite->success == 2) {
         ucx_test_suite_free(suite);
 
         printf("\nLibrary function tests\n");
@@ -112,6 +144,7 @@
         ucx_test_register(suite, test_ucx_map_put);
         ucx_test_register(suite, test_ucx_map_get);
         ucx_test_register(suite, test_ucx_map_iterator);
+        ucx_test_register(suite, test_ucx_map_iterator_chain);
         
         ucx_test_run(suite, stdout);
         ucx_test_suite_free(suite);
--- a/test/map_tests.c	Thu May 31 09:18:26 2012 +0200
+++ b/test/map_tests.c	Thu May 31 12:51:22 2012 +0200
@@ -4,20 +4,19 @@
 
 #include "map_tests.h"
 
-UCX_TEST_BEGIN(test_ucx_map_new) {
+UCX_TEST_IMPLEMENT(test_ucx_map_new) {
     UcxMap *map = ucx_map_new(16);
-    
+    UCX_TEST_BEGIN
     UCX_TEST_ASSERT(map->size == 16, "wrong size")
     UCX_TEST_ASSERT(map->map != NULL, "failed")
     
+    UCX_TEST_END
     ucx_map_free(map);
-    
-    UCX_TEST_END
 }
 
-UCX_TEST_BEGIN(test_ucx_key) {
-    
+UCX_TEST_IMPLEMENT(test_ucx_key) {
     UcxKey key = ucx_key("This is a text.", 15);
+    UCX_TEST_BEGIN
     UCX_TEST_ASSERT(strncmp(key.data, "This is a text.", 15) == 0, "failed")
     UCX_TEST_ASSERT(key.len == 15, "failed")
     UCX_TEST_ASSERT(key.hash == 1261186027, "hash failed")
@@ -25,13 +24,14 @@
     UCX_TEST_END
 }
 
-UCX_TEST_BEGIN(test_ucx_map_put) {
+UCX_TEST_IMPLEMENT(test_ucx_map_put) {
     
     UcxMap *map = ucx_map_new(4);
     
     int td[5];
     td[0] = 10; td[1] = 42; td[2] = 70; td[3] = 11200; td[4] = 80000;
 
+    UCX_TEST_BEGIN
     ucx_map_cstr_put(map, "Key2", &td[2]); /* 0 */
     ucx_map_cstr_put(map, "Key0", &td[0]); /* 0 */
     ucx_map_cstr_put(map, "Key1", &td[1]); /* 3 */
@@ -63,19 +63,18 @@
             "overwrite failed")
     UCX_TEST_ASSERT(map->map[0]->next->next->next == NULL, "overwrite failed")
     
+    UCX_TEST_END
     ucx_map_free(map);
-    
+}
+
+UCX_TEST_IMPLEMENT(test_ucx_map_get) {
+    UCX_TEST_BEGIN
+    UCX_TEST_ASSERT(0, "not implemented");
     UCX_TEST_END
 }
 
-UCX_TEST_BEGIN(test_ucx_map_get) {
-    // TODO:
-    UCX_TEST_END
-}
-
-UCX_TEST_BEGIN(test_ucx_map_iterator) {
-    UcxMap *map = ucx_map_new(16);
-    
+UCX_TEST_SUBROUTINE(test_ucx_map_itersrt, mapptr) {
+    UcxMap *map = (UcxMap*) mapptr;
     int v1 = 10;
     int v2 = 15;
     int v3 = 7;
@@ -97,29 +96,20 @@
 
     UCX_TEST_ASSERT(hit == 4, "test1: wrong number of hits");
     UCX_TEST_ASSERT(check == v1+v2+v3+v4, "test1: wrong result");
+}
 
+UCX_TEST_IMPLEMENT(test_ucx_map_iterator) {
+    UcxMap *map = ucx_map_new(16);
+    UCX_TEST_BEGIN
+    UCX_TEST_CALL_SUBROUTINE(test_ucx_map_itersrt, map)
+    UCX_TEST_END
     ucx_map_free(map);
-    
-    map = ucx_map_new(1);
-    ucx_map_cstr_put(map, "v1", &v1);
-    ucx_map_cstr_put(map, "v2", &v2);
-    ucx_map_cstr_put(map, "v3", &v3);
-    ucx_map_cstr_put(map, "v4", &v4);
-    
-    i = ucx_map_iterator(map);
-    check = 0;
-    hit = 0;
-    
-    UCX_MAP_FOREACH(int*, v, map, i) {
-        check += *v;
-        hit++;
-    }
-    
-    UCX_TEST_ASSERT(hit == 4, "test2: wrong number of hits");
-    UCX_TEST_ASSERT(check == v1+v2+v3+v4, "test2: wrong result");
-    
-    
+}
+
+UCX_TEST_IMPLEMENT(test_ucx_map_iterator_chain) {
+    UcxMap *map = ucx_map_new(1);
+    UCX_TEST_BEGIN
+    UCX_TEST_CALL_SUBROUTINE(test_ucx_map_itersrt, map)
+    UCX_TEST_END
     ucx_map_free(map);
-    
-    UCX_TEST_END
 }
--- a/test/map_tests.h	Thu May 31 09:18:26 2012 +0200
+++ b/test/map_tests.h	Thu May 31 12:51:22 2012 +0200
@@ -17,6 +17,7 @@
 UCX_TEST_DECLARE(test_ucx_map_put)
 UCX_TEST_DECLARE(test_ucx_map_get)
 UCX_TEST_DECLARE(test_ucx_map_iterator)
+UCX_TEST_DECLARE(test_ucx_map_iterator_chain)
 
 
 #ifdef	__cplusplus
--- a/test/mpool_tests.c	Thu May 31 09:18:26 2012 +0200
+++ b/test/mpool_tests.c	Thu May 31 12:51:22 2012 +0200
@@ -6,22 +6,20 @@
 
 #include "mpool_tests.h"
 
-UCX_TEST_BEGIN(test_ucx_mempool_new) {
+UCX_TEST_IMPLEMENT(test_ucx_mempool_new) {
     UcxMempool *pool = ucx_mempool_new(16);
-    
+    UCX_TEST_BEGIN
     UCX_TEST_ASSERT(pool->size == 16, "wrong size")
     UCX_TEST_ASSERT(pool->ndata == 0, "uninitialized counter")
     UCX_TEST_ASSERT(pool->data != NULL, "no memory addressed")
-    
+    UCX_TEST_END
     ucx_mempool_free(pool);
-    
-    UCX_TEST_END
 }
 
-UCX_TEST_BEGIN(test_ucx_mempool_malloc) {
+UCX_TEST_IMPLEMENT(test_ucx_mempool_malloc) {
     
     UcxMempool *pool = ucx_mempool_new(1);
-    
+    UCX_TEST_BEGIN
     intptr_t *test = (intptr_t*) ucx_mempool_malloc(pool, sizeof(intptr_t));
     
     UCX_TEST_ASSERT(pool->ndata == 1, "counter not incremented")
@@ -33,15 +31,14 @@
     
     UCX_TEST_ASSERT(*test == 5, "wrong pointer")
     
+    UCX_TEST_END
     ucx_mempool_free(pool);
-    
-    UCX_TEST_END
 }
 
-UCX_TEST_BEGIN(test_ucx_mempool_malloc_with_chcap) {
+UCX_TEST_IMPLEMENT(test_ucx_mempool_malloc_with_chcap) {
     
     UcxMempool *pool = ucx_mempool_new(1);
-    
+    UCX_TEST_BEGIN
     ucx_mempool_malloc(pool, sizeof(int));
     intptr_t *test = (intptr_t*) ucx_mempool_malloc(pool, sizeof(intptr_t));
     
@@ -54,23 +51,22 @@
     
     UCX_TEST_ASSERT(*test == 5, "wrong pointer")
     
+    UCX_TEST_END
     ucx_mempool_free(pool);
-    
-    UCX_TEST_END
 }
 
-UCX_TEST_BEGIN(test_ucx_mempool_calloc) {
+UCX_TEST_IMPLEMENT(test_ucx_mempool_calloc) {
     
     UcxMempool *pool = ucx_mempool_new(1);
+    UCX_TEST_BEGIN
     
     intptr_t *test = (intptr_t*) ucx_mempool_calloc(pool, 2, sizeof(intptr_t));
     
     UCX_TEST_ASSERT(test != NULL, "no memory for test data")
     UCX_TEST_ASSERT(test[0] == 0 && test[1] == 0, "failed")
     
+    UCX_TEST_END
     ucx_mempool_free(pool);
-    
-    UCX_TEST_END
 }
 
 void test_setdestr(void* elem) {
@@ -78,14 +74,15 @@
     *cb = 42;
 }
 
-UCX_TEST_BEGIN(test_ucx_mempool_set_destr) {
+UCX_TEST_IMPLEMENT(test_ucx_mempool_set_destr) {
     
+    intptr_t *cb = (intptr_t*) malloc(sizeof(intptr_t));
+    UCX_TEST_BEGIN
     UcxMempool *pool = ucx_mempool_new(2);
     
     ucx_mempool_malloc(pool, sizeof(intptr_t));
     intptr_t *test = (intptr_t*) ucx_mempool_calloc(pool, 2, sizeof(intptr_t));
     
-    intptr_t *cb = (intptr_t*) malloc(sizeof(intptr_t));
     UCX_TEST_ASSERT(cb != NULL && test != NULL, "no memory for test data")
     
     test[0] = 5; test[1] = (intptr_t) cb;
@@ -100,20 +97,19 @@
     ucx_mempool_free(pool);
     
     UCX_TEST_ASSERT(*cb == 42, "destructor not called")
-
-    free(cb);
     
     UCX_TEST_END
+    if (cb != NULL) free(cb);
 }
 
 
-UCX_TEST_BEGIN(test_ucx_mempool_reg_destr) {
+UCX_TEST_IMPLEMENT(test_ucx_mempool_reg_destr) {
     
+    intptr_t *test = (intptr_t*) calloc(2, sizeof(intptr_t));
+    intptr_t *cb = (intptr_t*) malloc(sizeof(intptr_t));
+    UCX_TEST_BEGIN
     UcxMempool *pool = ucx_mempool_new(1);
     
-    intptr_t *test = (intptr_t*) calloc(2, sizeof(intptr_t));
-    
-    intptr_t *cb = (intptr_t*) malloc(sizeof(intptr_t));
     UCX_TEST_ASSERT(cb != NULL && test != NULL, "no memory for test data")
     
     test[0] = 5; test[1] = (intptr_t) cb;
@@ -127,23 +123,22 @@
     UCX_TEST_ASSERT(*pooladdr == test_setdestr, "failed")
     
     ucx_mempool_free(pool);
-    free(test);
-    
     UCX_TEST_ASSERT(*cb == 42, "destructor not called")
+    UCX_TEST_END
 
-    free(cb);
-    
-    UCX_TEST_END
+    if (test != NULL) free(test);
+    if (cb != NULL) free(cb);
 }
 
-UCX_TEST_BEGIN(test_ucx_mempool_realloc) {
-    
+UCX_TEST_IMPLEMENT(test_ucx_mempool_realloc) {
+
+    intptr_t *cb = (intptr_t*) malloc(sizeof(intptr_t));
+    UCX_TEST_BEGIN
     UcxMempool *pool = ucx_mempool_new(2);
     
     ucx_mempool_malloc(pool, sizeof(intptr_t));
     intptr_t *test = (intptr_t*) ucx_mempool_calloc(pool, 2, sizeof(intptr_t));
-    
-    intptr_t *cb = (intptr_t*) malloc(sizeof(intptr_t));
+
     UCX_TEST_ASSERT(cb != NULL && test != NULL, "no memory for test data")
     
     test[0] = 5; test[1] = (intptr_t) cb;
@@ -167,8 +162,7 @@
     ucx_mempool_free(pool);
     
     UCX_TEST_ASSERT(*cb == 42, "destructor not called")
-
-    free(cb);
     
     UCX_TEST_END
+    if (cb != NULL) free(cb);
 }
--- a/ucx/test.h	Thu May 31 09:18:26 2012 +0200
+++ b/ucx/test.h	Thu May 31 12:51:22 2012 +0200
@@ -3,6 +3,31 @@
  * Author: Mike
  *
  * Created on 18. Februar 2012, 14:15
+ *
+ *
+ *
+ * Usage of this test framework:
+ *
+ * **** IN HEADER FILE: ****
+ *
+ * UCX_TEST_DECLARE(function_name)
+ *
+ * **** IN SOURCE FILE: ****
+ *
+ * UCX_TEST_IMPLEMENT(function_name) {
+ *  <memory allocation and other stuff here>
+ *  UCX_TEST_BEGIN
+ *  <tests with UCX_TEST_ASSERT here>
+ *  UCX_TEST_END
+ *  <cleanup of memory here>
+ * }
+ *
+ * PLEASE NOTE: if a test fails, a longjump is performed
+ * back to the UCX_TEST_BEGIN macro!
+ *
+ * You may use multiple BEGIN-END blocks if you are aware of the
+ * longjmp behaviour.
+ *
  */
 
 #ifndef TEST_H
@@ -10,6 +35,7 @@
 
 #include <stdio.h>
 #include <string.h>
+#include <setjmp.h>
 #include "list.h"
 
 #ifdef	__cplusplus
@@ -31,16 +57,25 @@
 void ucx_test_run(UcxTestSuite*, FILE*);
 
 #define UCX_TEST_DECLARE(name) void name(UcxTestSuite*,FILE *);
-#define UCX_TEST_BEGIN(name) void name(UcxTestSuite* _suite_,FILE *_output_) {\
-    fwrite("Running "#name"... ", 1, 12+strlen(#name), _output_);
+#define UCX_TEST_IMPLEMENT(name) void name(UcxTestSuite* _suite_,FILE *_output_)
+
+#define UCX_TEST_BEGIN fwrite("Running ", 1, 8, _output_);\
+        fwrite(__func__, 1, strlen(__func__), _output_);\
+        fwrite("... ", 1, 4, _output_);\
+        jmp_buf _env_; \
+        if (!setjmp(_env_)) {
 
 #define UCX_TEST_ASSERT(condition,message) if (!(condition)) { \
         fwrite(message".\n", 1, 2+strlen(message), _output_); \
         _suite_->failure++; \
-        return;\
+        longjmp(_env_, 1);\
     }
 
-#define UCX_TEST_END } fwrite("success.\n", 1, 9, _output_); _suite_->success++;
+#define UCX_TEST_SUBROUTINE(name,data) void name(UcxTestSuite* _suite_,\
+        FILE *_output_, jmp_buf _env_, void* data)
+#define UCX_TEST_CALL_SUBROUTINE(name,data) name(_suite_,_output_,_env_,data);
+
+#define UCX_TEST_END fwrite("success.\n", 1, 9, _output_); _suite_->success++;}
 
 #ifdef	__cplusplus
 }

mercurial