lib/tinytest: Clean up test reporting in the presence of stdout output.

tinytest is written with the idea that tests won't write to stdout, so it
prints test name witjout newline, then executes test, then writes status.
But MicroPython tests write to stdout, so the test output becomes a mess.
So, instead print it like:

    # starting basics/andor.py
    ... test output ...
    basics/andor.py: OK
This commit is contained in:
Paul Sokolovsky 2017-12-15 19:41:08 +02:00
parent dd35fe7ca0
commit f4ed2dfa94
1 changed files with 5 additions and 2 deletions

View File

@ -234,8 +234,9 @@ testcase_run_one(const struct testgroup_t *group,
return SKIP; return SKIP;
} }
printf("# starting %s%s\n", group->prefix, testcase->name);
if (opt_verbosity>0 && !opt_forked) { if (opt_verbosity>0 && !opt_forked) {
printf("%s%s: ", group->prefix, testcase->name); //printf("%s%s: ", group->prefix, testcase->name);
} else { } else {
if (opt_verbosity==0) printf("."); if (opt_verbosity==0) printf(".");
cur_test_prefix = group->prefix; cur_test_prefix = group->prefix;
@ -252,6 +253,7 @@ testcase_run_one(const struct testgroup_t *group,
outcome = testcase_run_bare_(testcase); outcome = testcase_run_bare_(testcase);
} }
printf("%s%s: ", group->prefix, testcase->name);
if (outcome == OK) { if (outcome == OK) {
++n_ok; ++n_ok;
if (opt_verbosity>0 && !opt_forked) if (opt_verbosity>0 && !opt_forked)
@ -263,7 +265,8 @@ testcase_run_one(const struct testgroup_t *group,
} else { } else {
++n_bad; ++n_bad;
if (!opt_forked) if (!opt_forked)
printf("\n [%s FAILED]\n", testcase->name); //printf("\n [%s FAILED]\n", testcase->name);
puts("FAILED");
} }
if (opt_forked) { if (opt_forked) {