diff options
author | Simon Glass <sjg@chromium.org> | 2017-11-25 11:57:29 -0700 |
---|---|---|
committer | Tom Rini <trini@konsulko.com> | 2017-12-02 18:32:58 -0500 |
commit | 4d869c1e49e5a276bd53f50a83e78999a25e2846 (patch) | |
tree | 43478b125299c63748298b33f400e9a6ecd08d03 /test/cmd_ut.c | |
parent | b59670f2bd028b682cfab88a9c8e980a968f24bd (diff) | |
download | u-boot-4d869c1e49e5a276bd53f50a83e78999a25e2846.tar.gz |
test: Add a command function for test execution
The logic to either iterate through a list of tests or pick a named test
is common to at lest two test suits. Move this logic into a new function
and call it from the environment tests.
Signed-off-by: Simon Glass <sjg@chromium.org>
Diffstat (limited to 'test/cmd_ut.c')
-rw-r--r-- | test/cmd_ut.c | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/test/cmd_ut.c b/test/cmd_ut.c index 14333423a1..d860dd72f0 100644 --- a/test/cmd_ut.c +++ b/test/cmd_ut.c @@ -8,9 +8,34 @@ #include <common.h> #include <command.h> #include <test/suites.h> +#include <test/test.h> static int do_ut_all(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]); +int cmd_ut_category(const char *name, struct unit_test *tests, int n_ents, + int argc, char * const argv[]) +{ + struct unit_test_state uts = { .fail_count = 0 }; + struct unit_test *test; + + if (argc == 1) + printf("Running %d %s tests\n", n_ents, name); + + for (test = tests; test < tests + n_ents; test++) { + if (argc > 1 && strcmp(argv[1], test->name)) + continue; + printf("Test: %s\n", test->name); + + uts.start = mallinfo(); + + test->func(&uts); + } + + printf("Failures: %d\n", uts.fail_count); + + return uts.fail_count ? CMD_RET_FAILURE : 0; +} + static cmd_tbl_t cmd_ut_sub[] = { U_BOOT_CMD_MKENT(all, CONFIG_SYS_MAXARGS, 1, do_ut_all, "", ""), #if defined(CONFIG_UT_DM) |