X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=test%2Fdm%2Ftest-main.c;h=f2e0048143874549750b61342378c117f0d85363;hb=de7781158923a9c87debc5a89ce4fabfd0fc93bc;hp=0477d2fa735d423d880fcfc2da8042db38344f38;hpb=b6227d3993db8f1763a8bd377b189e7b77cfe885;p=u-boot diff --git a/test/dm/test-main.c b/test/dm/test-main.c index 0477d2fa73..f2e0048143 100644 --- a/test/dm/test-main.c +++ b/test/dm/test-main.c @@ -6,9 +6,11 @@ #include #include +#include #include #include #include +#include #include #include #include @@ -74,8 +76,12 @@ static int dm_test_main(const char *test_name) struct unit_test *tests = ll_entry_start(struct unit_test, dm_test); const int n_ents = ll_entry_count(struct unit_test, dm_test); struct unit_test_state *uts = &global_dm_test_state; + struct sandbox_state *state = state_get_current(); uts->priv = &_global_priv_dm_test_state; struct unit_test *test; + int run_count; + + uts->fail_count = 0; /* * If we have no device tree, or it only has a root node, then these @@ -90,10 +96,17 @@ static int dm_test_main(const char *test_name) if (!test_name) printf("Running %d driver model tests\n", n_ents); + run_count = 0; for (test = tests; test < tests + n_ents; test++) { - if (test_name && strcmp(test_name, test->name)) + const char *name = test->name; + + /* All tests have this prefix */ + if (!strncmp(name, "dm_test_", 8)) + name += 8; + if (test_name && strcmp(test_name, name)) continue; printf("Test: %s\n", test->name); + run_count++; ut_assertok(dm_test_init(uts)); uts->start = mallinfo(); @@ -104,12 +117,24 @@ static int dm_test_main(const char *test_name) if (test->flags & DM_TESTF_SCAN_FDT) ut_assertok(dm_scan_fdt(gd->fdt_blob, false)); + /* + * Silence the console and rely on console reocrding to get + * our output. + */ + console_record_reset(); + if (!state->show_test_output) + gd->flags |= GD_FLG_SILENT; test->func(uts); + gd->flags &= ~GD_FLG_SILENT; + state_set_skip_delays(false); ut_assertok(dm_test_destroy(uts)); } - printf("Failures: %d\n", uts->fail_count); + if (test_name && !run_count) + printf("Test '%s' not found\n", test_name); + else + printf("Failures: %d\n", uts->fail_count); gd->dm_root = NULL; ut_assertok(dm_init());