Kunit test modules usually contain one test suite, named after the module
name with the trailing "_test" or "_kunit" suffix omitted.  Since we
follow the same convention when we derive subtest names from module names,
there is a great chance that those two names match.  Take this into
account when composing names for IGT dynamic sub-subtest names and drop
the leading test suite name component when it is the same as subtest name.

Signed-off-by: Janusz Krzysztofik <janusz.krzyszto...@linux.intel.com>
Reviewed-by: Mauro Carvalho Chehab <mche...@kernel.org>
---
 lib/igt_kmod.c | 11 ++++++++---
 1 file changed, 8 insertions(+), 3 deletions(-)

diff --git a/lib/igt_kmod.c b/lib/igt_kmod.c
index 7bca4cdaab..387efbb59f 100644
--- a/lib/igt_kmod.c
+++ b/lib/igt_kmod.c
@@ -885,7 +885,8 @@ static void kunit_result_free(struct igt_ktap_result **r,
        *r = NULL;
 }
 
-static void __igt_kunit(struct igt_ktest *tst, const char *opts)
+static void
+__igt_kunit(struct igt_ktest *tst, const char *name, const char *opts)
 {
        struct modprobe_data modprobe = { pthread_self(), tst->kmod, opts, 0, };
        char *suite_name = NULL, *case_name = NULL;
@@ -928,7 +929,11 @@ static void __igt_kunit(struct igt_ktest *tst, const char 
*opts)
 
                r = igt_list_first_entry(&results, r, link);
 
-               igt_dynamic_f("%s-%s", r->suite_name, r->case_name) {
+               igt_dynamic_f("%s%s%s",
+                             strcmp(r->suite_name, name) ?  r->suite_name : "",
+                             strcmp(r->suite_name, name) ? "-" : "",
+                             r->case_name) {
+
                        if (r->code == IGT_EXIT_INVALID) {
                                /* parametrized test case, get actual result */
                                kunit_result_free(&r, &suite_name, &case_name);
@@ -1069,7 +1074,7 @@ void igt_kunit(const char *module_name, const char *name, 
const char *opts)
         * and for documentation.
         */
        igt_subtest_with_dynamic(name)
-               __igt_kunit(&tst, opts);
+               __igt_kunit(&tst, name, opts);
 
        igt_fixture
                igt_ktest_end(&tst);
-- 
2.42.0

Reply via email to