Commit 91f77560 authored by Alexei Starovoitov's avatar Alexei Starovoitov

Merge branch 'test_progs-improvements'

Jesper Dangaard Brouer says:

====================
V3: Reorder patches to cause less code churn.

The BPF selftest 'test_progs' contains many tests, that cover all the
different areas of the kernel where BPF is used.  The CI system sees this
as one test, which is impractical for identifying what team/engineer is
responsible for debugging the problem.

This patchset add some options that makes it easier to create a shell
for-loop that invoke each (top-level) test avail in test_progs. Then each
test FAIL/PASS result can be presented the CI system to have a separate
bullet. (For Red Hat use-case in Beaker https://beaker-project.org/)

Created a public script[1] that uses these features in an advanced way.
Demonstrating howto reduce the number of (top-level) tests by grouping tests
together via using the existing test pattern selection feature, and then
using the new --list feature combined with exclude (-b) to get a list of
remaining test names that was not part of the groups.

[1] https://github.com/netoptimizer/prototype-kernel/blob/master/scripts/bpf_selftests_grouping.sh
====================
Signed-off-by: default avatarAlexei Starovoitov <ast@kernel.org>
parents 17bbf925 c1f1f365
...@@ -366,6 +366,8 @@ enum ARG_KEYS { ...@@ -366,6 +366,8 @@ enum ARG_KEYS {
ARG_TEST_NAME_BLACKLIST = 'b', ARG_TEST_NAME_BLACKLIST = 'b',
ARG_VERIFIER_STATS = 's', ARG_VERIFIER_STATS = 's',
ARG_VERBOSE = 'v', ARG_VERBOSE = 'v',
ARG_GET_TEST_CNT = 'c',
ARG_LIST_TEST_NAMES = 'l',
}; };
static const struct argp_option opts[] = { static const struct argp_option opts[] = {
...@@ -379,6 +381,10 @@ static const struct argp_option opts[] = { ...@@ -379,6 +381,10 @@ static const struct argp_option opts[] = {
"Output verifier statistics", }, "Output verifier statistics", },
{ "verbose", ARG_VERBOSE, "LEVEL", OPTION_ARG_OPTIONAL, { "verbose", ARG_VERBOSE, "LEVEL", OPTION_ARG_OPTIONAL,
"Verbose output (use -vv or -vvv for progressively verbose output)" }, "Verbose output (use -vv or -vvv for progressively verbose output)" },
{ "count", ARG_GET_TEST_CNT, NULL, 0,
"Get number of selected top-level tests " },
{ "list", ARG_LIST_TEST_NAMES, NULL, 0,
"List test names that would run (without running them) " },
{}, {},
}; };
...@@ -511,6 +517,12 @@ static error_t parse_arg(int key, char *arg, struct argp_state *state) ...@@ -511,6 +517,12 @@ static error_t parse_arg(int key, char *arg, struct argp_state *state)
} }
} }
break; break;
case ARG_GET_TEST_CNT:
env->get_test_cnt = true;
break;
case ARG_LIST_TEST_NAMES:
env->list_test_names = true;
break;
case ARGP_KEY_ARG: case ARGP_KEY_ARG:
argp_usage(state); argp_usage(state);
break; break;
...@@ -654,6 +666,17 @@ int main(int argc, char **argv) ...@@ -654,6 +666,17 @@ int main(int argc, char **argv)
test->test_num, test->test_name)) test->test_num, test->test_name))
continue; continue;
if (env.get_test_cnt) {
env.succ_cnt++;
continue;
}
if (env.list_test_names) {
fprintf(env.stdout, "%s\n", test->test_name);
env.succ_cnt++;
continue;
}
test->run_test(); test->run_test();
/* ensure last sub-test is finalized properly */ /* ensure last sub-test is finalized properly */
if (test->subtest_name) if (test->subtest_name)
...@@ -677,9 +700,19 @@ int main(int argc, char **argv) ...@@ -677,9 +700,19 @@ int main(int argc, char **argv)
cleanup_cgroup_environment(); cleanup_cgroup_environment();
} }
stdio_restore(); stdio_restore();
if (env.get_test_cnt) {
printf("%d\n", env.succ_cnt);
goto out;
}
if (env.list_test_names)
goto out;
fprintf(stdout, "Summary: %d/%d PASSED, %d SKIPPED, %d FAILED\n", fprintf(stdout, "Summary: %d/%d PASSED, %d SKIPPED, %d FAILED\n",
env.succ_cnt, env.sub_succ_cnt, env.skip_cnt, env.fail_cnt); env.succ_cnt, env.sub_succ_cnt, env.skip_cnt, env.fail_cnt);
out:
free_str_set(&env.test_selector.blacklist); free_str_set(&env.test_selector.blacklist);
free_str_set(&env.test_selector.whitelist); free_str_set(&env.test_selector.whitelist);
free(env.test_selector.num_set); free(env.test_selector.num_set);
...@@ -687,5 +720,8 @@ int main(int argc, char **argv) ...@@ -687,5 +720,8 @@ int main(int argc, char **argv)
free_str_set(&env.subtest_selector.whitelist); free_str_set(&env.subtest_selector.whitelist);
free(env.subtest_selector.num_set); free(env.subtest_selector.num_set);
if (env.succ_cnt + env.fail_cnt + env.skip_cnt == 0)
return EXIT_FAILURE;
return env.fail_cnt ? EXIT_FAILURE : EXIT_SUCCESS; return env.fail_cnt ? EXIT_FAILURE : EXIT_SUCCESS;
} }
...@@ -66,6 +66,8 @@ struct test_env { ...@@ -66,6 +66,8 @@ struct test_env {
enum verbosity verbosity; enum verbosity verbosity;
bool jit_enabled; bool jit_enabled;
bool get_test_cnt;
bool list_test_names;
struct prog_test_def *test; struct prog_test_def *test;
FILE *stdout; FILE *stdout;
......
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