Commit f667d1d6 authored by Yucong Sun's avatar Yucong Sun Committed by Andrii Nakryiko

selftests/bpf: Correctly display subtest skip status

In skip_account(), test->skip_cnt is set to 0 at the end, this makes next print
statement never display SKIP status for the subtest. This patch moves the
accounting logic after the print statement, fixing the issue.

This patch also added SKIP status display for normal tests.
Signed-off-by: default avatarYucong Sun <fallentree@fb.com>
Signed-off-by: default avatarAndrii Nakryiko <andrii@kernel.org>
Link: https://lore.kernel.org/bpf/20210817044732.3263066-3-fallentree@fb.com
parent 26d82640
...@@ -148,18 +148,18 @@ void test__end_subtest() ...@@ -148,18 +148,18 @@ void test__end_subtest()
struct prog_test_def *test = env.test; struct prog_test_def *test = env.test;
int sub_error_cnt = test->error_cnt - test->old_error_cnt; int sub_error_cnt = test->error_cnt - test->old_error_cnt;
if (sub_error_cnt)
env.fail_cnt++;
else if (test->skip_cnt == 0)
env.sub_succ_cnt++;
skip_account();
dump_test_log(test, sub_error_cnt); dump_test_log(test, sub_error_cnt);
fprintf(env.stdout, "#%d/%d %s:%s\n", fprintf(env.stdout, "#%d/%d %s:%s\n",
test->test_num, test->subtest_num, test->subtest_name, test->test_num, test->subtest_num, test->subtest_name,
sub_error_cnt ? "FAIL" : (test->skip_cnt ? "SKIP" : "OK")); sub_error_cnt ? "FAIL" : (test->skip_cnt ? "SKIP" : "OK"));
if (sub_error_cnt)
env.fail_cnt++;
else if (test->skip_cnt == 0)
env.sub_succ_cnt++;
skip_account();
free(test->subtest_name); free(test->subtest_name);
test->subtest_name = NULL; test->subtest_name = NULL;
} }
...@@ -786,17 +786,18 @@ int main(int argc, char **argv) ...@@ -786,17 +786,18 @@ int main(int argc, char **argv)
test__end_subtest(); test__end_subtest();
test->tested = true; test->tested = true;
if (test->error_cnt)
env.fail_cnt++;
else
env.succ_cnt++;
skip_account();
dump_test_log(test, test->error_cnt); dump_test_log(test, test->error_cnt);
fprintf(env.stdout, "#%d %s:%s\n", fprintf(env.stdout, "#%d %s:%s\n",
test->test_num, test->test_name, test->test_num, test->test_name,
test->error_cnt ? "FAIL" : "OK"); test->error_cnt ? "FAIL" : (test->skip_cnt ? "SKIP" : "OK"));
if (test->error_cnt)
env.fail_cnt++;
else
env.succ_cnt++;
skip_account();
reset_affinity(); reset_affinity();
restore_netns(); restore_netns();
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment