X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=tests%2Ftest.c;h=903ad4ee9e87610741a56bb9f1590fc16969405d;hb=f5c167f523682cb08109842ce010b29e80fdf63d;hp=fb501fadc2edcc6d57270c2cd47ce52cdc21a5d8;hpb=c859868660e37e0e6c1ed168c0b063652e0ea9bd;p=m6w6%2Flibmemcached diff --git a/tests/test.c b/tests/test.c index fb501fad..903ad4ee 100644 --- a/tests/test.c +++ b/tests/test.c @@ -19,11 +19,18 @@ #include #include #include +#include #include "test.h" static void world_stats_print(world_stats_st *stats) { + fputc('\n', stderr); + fprintf(stderr, "Total Collections\t\t\t\t%u\n", stats->collection_total); + fprintf(stderr, "\tFailed Collections\t\t\t%u\n", stats->collection_failed); + fprintf(stderr, "\tSkipped Collections\t\t\t%u\n", stats->collection_skipped); + fprintf(stderr, "\tSucceeded Collections\t\t%u\n", stats->collection_success); + fputc('\n', stderr); fprintf(stderr, "Total\t\t\t\t%u\n", stats->total); fprintf(stderr, "\tFailed\t\t\t%u\n", stats->failed); fprintf(stderr, "\tSkipped\t\t\t%u\n", stats->skipped); @@ -98,6 +105,34 @@ static world_runner_st defualt_runners= { _runner_default }; +static test_return_t _default_callback(void *p) +{ + (void)p; + + return TEST_SUCCESS; +} + +static inline void set_default_fn(test_callback_fn *fn) +{ + if (*fn == NULL) + { + *fn= _default_callback; + } +} + +static collection_st *init_world(world_st *world) +{ + if (! world->runner) + { + world->runner= &defualt_runners; + } + + set_default_fn(&world->collection.startup); + set_default_fn(&world->collection.shutdown); + + return world->collections; +} + int main(int argc, char *argv[]) { @@ -116,12 +151,7 @@ int main(int argc, char *argv[]) memset(&world, 0, sizeof(world)); get_world(&world); - if (! world.runner) - { - world.runner= &defualt_runners; - } - - collection= world.collections; + collection= init_world(&world); if (world.create) { @@ -143,13 +173,38 @@ int main(int argc, char *argv[]) for (next= collection; next->name; next++) { + test_return_t collection_rc= TEST_SUCCESS; test_st *run; + bool failed= false; + bool skipped= false; run= next->tests; if (collection_to_run && fnmatch(collection_to_run, next->name, 0)) continue; - fprintf(stderr, "\n%s\n\n", next->name); + stats.collection_total++; + + collection_rc= world.collection.startup(world_ptr); + + switch (collection_rc) + { + case TEST_SUCCESS: + fprintf(stderr, "\n%s\n\n", next->name); + break; + case TEST_FAILURE: + fprintf(stderr, "\n%s [ failed ]\n\n", next->name); + stats.failed++; + continue; + case TEST_SKIPPED: + fprintf(stderr, "\n%s [ skipping ]\n\n", next->name); + stats.skipped++; + continue; + case TEST_MEMORY_ALLOCATION_FAILURE: + case TEST_MAXIMUM_RETURN: + default: + assert(0); + break; + } for (x= 0; run->name; run++) { @@ -161,45 +216,48 @@ int main(int argc, char *argv[]) fprintf(stderr, "Testing %s", run->name); - if (world.collection_startup) + if (world.test.startup) { - world.collection_startup(world_ptr); + world.test.startup(world_ptr); } - if (run->requires_flush && world.flush) + if (run->requires_flush && world.test.flush) { - world.flush(world_ptr); + world.test.flush(world_ptr); } - if (world.pre_run) + if (world.test.pre_run) { - world.pre_run(world_ptr); + world.test.pre_run(world_ptr); } - if (next->pre && world.runner->pre) + // Runner code { - return_code= world.runner->pre(next->pre, world_ptr); - - if (return_code != TEST_SUCCESS) + if (next->pre && world.runner->pre) { - goto error; + return_code= world.runner->pre(next->pre, world_ptr); + + if (return_code != TEST_SUCCESS) + { + goto error; + } } - } - gettimeofday(&start_time, NULL); - return_code= world.runner->run(run->test_fn, world_ptr); - gettimeofday(&end_time, NULL); - load_time= timedif(end_time, start_time); + gettimeofday(&start_time, NULL); + return_code= world.runner->run(run->test_fn, world_ptr); + gettimeofday(&end_time, NULL); + load_time= timedif(end_time, start_time); - if (next->post && world.runner->post) - { - (void) world.runner->post(next->post, world_ptr); + if (next->post && world.runner->post) + { + (void) world.runner->post(next->post, world_ptr); + } } - if (world.post_run) + if (world.test.post_run) { - world.post_run(world_ptr); + world.test.post_run(world_ptr); } error: @@ -215,30 +273,59 @@ error: break; case TEST_FAILURE: stats.failed++; + failed= true; break; case TEST_SKIPPED: stats.skipped++; + skipped= true; break; case TEST_MEMORY_ALLOCATION_FAILURE: + fprintf(stderr, "Exhausted memory, quitting\n"); + abort(); case TEST_MAXIMUM_RETURN: default: + assert(0); // Coding error. break; } fprintf(stderr, "[ %s ]\n", test_strerror(return_code)); - if (world.on_error) + if (world.test.on_error) { test_return_t rc; - rc= world.on_error(return_code, world_ptr); + rc= world.test.on_error(return_code, world_ptr); if (rc != TEST_SUCCESS) break; } } + + if (failed) + { + stats.collection_failed++; + } + + if (skipped) + { + stats.collection_skipped++; + } + + if (! failed && ! skipped) + { + stats.collection_success++; + } + + world.collection.shutdown(world_ptr); } - fprintf(stderr, "All tests completed successfully\n\n"); + if (stats.collection_failed || stats.collection_skipped) + { + fprintf(stderr, "Some test failures and/or skipped test occurred.\n\n"); + } + else + { + fprintf(stderr, "All tests completed successfully\n\n"); + } if (world.destroy) {