test: store only the test case name

Store only the test case name in unit test case structure.The actor who
renders the test status can add appropriate test status. This enables
adding the new test case status without storing the additional
information in the unit test case structure.

Signed-off-by: Jerin Jacob <jerin.jacob@caviumnetworks.com>
Tested-by: Harry van Haaren <harry.van.haaren@intel.com>
Acked-by: Harry van Haaren <harry.van.haaren@intel.com>
This commit is contained in:
Jerin Jacob 2017-03-19 19:07:33 +05:30 committed by Thomas Monjalon
parent 083c1fb5f4
commit 151f4d0341
2 changed files with 15 additions and 22 deletions

View File

@ -158,6 +158,7 @@ unit_test_suite_runner(struct unit_test_suite *suite)
{ {
int test_success; int test_success;
unsigned total = 0, executed = 0, skipped = 0, succeeded = 0, failed = 0; unsigned total = 0, executed = 0, skipped = 0, succeeded = 0, failed = 0;
const char *status;
if (suite->suite_name) { if (suite->suite_name) {
printf(" + ------------------------------------------------------- +\n"); printf(" + ------------------------------------------------------- +\n");
@ -201,15 +202,12 @@ unit_test_suite_runner(struct unit_test_suite *suite)
suite->unit_test_cases[total].teardown(); suite->unit_test_cases[total].teardown();
if (test_success == TEST_SUCCESS) if (test_success == TEST_SUCCESS)
printf(" + TestCase [%2d] : %s\n", total, status = "succeeded";
suite->unit_test_cases[total].success_msg ?
suite->unit_test_cases[total].success_msg :
"passed");
else else
printf(" + TestCase [%2d] : %s\n", total, status = "failed";
suite->unit_test_cases[total].fail_msg ?
suite->unit_test_cases[total].fail_msg : printf(" + TestCase [%2d] : %s %s\n", total,
"failed"); suite->unit_test_cases[total].name, status);
total++; total++;
} }

View File

@ -185,29 +185,24 @@ struct unit_test_case {
int (*setup)(void); int (*setup)(void);
void (*teardown)(void); void (*teardown)(void);
int (*testcase)(void); int (*testcase)(void);
const char *success_msg; const char *name;
const char *fail_msg;
unsigned enabled; unsigned enabled;
}; };
#define TEST_CASE(fn) { NULL, NULL, fn, #fn " succeeded", #fn " failed", 1 } #define TEST_CASE(fn) { NULL, NULL, fn, #fn, 1 }
#define TEST_CASE_NAMED(name, fn) { NULL, NULL, fn, name " succeeded", \ #define TEST_CASE_NAMED(name, fn) { NULL, NULL, fn, name, 1 }
name " failed", 1 }
#define TEST_CASE_ST(setup, teardown, testcase) \ #define TEST_CASE_ST(setup, teardown, testcase) \
{ setup, teardown, testcase, #testcase " succeeded", \ { setup, teardown, testcase, #testcase, 1 }
#testcase " failed ", 1 }
#define TEST_CASE_DISABLED(fn) { NULL, NULL, fn, #fn " succeeded", \ #define TEST_CASE_DISABLED(fn) { NULL, NULL, fn, #fn, 0 }
#fn " failed", 0 }
#define TEST_CASE_ST_DISABLED(setup, teardown, testcase) \ #define TEST_CASE_ST_DISABLED(setup, teardown, testcase) \
{ setup, teardown, testcase, #testcase " succeeded", \ { setup, teardown, testcase, #testcase, 0 }
#testcase " failed ", 0 }
#define TEST_CASES_END() { NULL, NULL, NULL, NULL, NULL, 0 } #define TEST_CASES_END() { NULL, NULL, NULL, NULL, 0 }
#if RTE_LOG_LEVEL >= RTE_LOG_DEBUG #if RTE_LOG_LEVEL >= RTE_LOG_DEBUG
#define TEST_HEXDUMP(file, title, buf, len) rte_hexdump(file, title, buf, len) #define TEST_HEXDUMP(file, title, buf, len) rte_hexdump(file, title, buf, len)