kunit: tool: fix parsing of test attributes
authorRae Moar <rmoar@google.com>
Thu, 7 Dec 2023 21:34:09 +0000 (21:34 +0000)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 5 Feb 2024 20:14:15 +0000 (20:14 +0000)
[ Upstream commit 8ae27bc7fff4ef467a7964821a6cedb34a05d3b2 ]

Add parsing of attributes as diagnostic data. Fixes issue with test plan
being parsed incorrectly as diagnostic data when located after
suite-level attributes.

Note that if there does not exist a test plan line, the diagnostic lines
between the suite header and the first result will be saved in the suite
log rather than the first test case log.

Signed-off-by: Rae Moar <rmoar@google.com>
Reviewed-by: David Gow <davidgow@google.com>
Signed-off-by: Shuah Khan <skhan@linuxfoundation.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
tools/testing/kunit/kunit_parser.py

index 79d8832..ce34be1 100644 (file)
@@ -450,7 +450,7 @@ def parse_diagnostic(lines: LineStream) -> List[str]:
        Log of diagnostic lines
        """
        log = []  # type: List[str]
-       non_diagnostic_lines = [TEST_RESULT, TEST_HEADER, KTAP_START, TAP_START]
+       non_diagnostic_lines = [TEST_RESULT, TEST_HEADER, KTAP_START, TAP_START, TEST_PLAN]
        while lines and not any(re.match(lines.peek())
                        for re in non_diagnostic_lines):
                log.append(lines.pop())
@@ -726,6 +726,7 @@ def parse_test(lines: LineStream, expected_num: int, log: List[str], is_subtest:
                # test plan
                test.name = "main"
                ktap_line = parse_ktap_header(lines, test)
+               test.log.extend(parse_diagnostic(lines))
                parse_test_plan(lines, test)
                parent_test = True
        else:
@@ -737,6 +738,7 @@ def parse_test(lines: LineStream, expected_num: int, log: List[str], is_subtest:
                if parent_test:
                        # If KTAP version line and/or subtest header is found, attempt
                        # to parse test plan and print test header
+                       test.log.extend(parse_diagnostic(lines))
                        parse_test_plan(lines, test)
                        print_test_header(test)
        expected_count = test.expected_count