From: Thomas Weißschuh <[email protected]>

Running the KUnit testsuite through pytest fails, as the function
test_data_path() is recognized as a test function. Its execution fails
as pytest tries to resolve the 'path' argument as a fixture which does
not exist.

Rename the function, so the helper function is not incorrectly
recognized as a test function.

Signed-off-by: Thomas Weißschuh <[email protected]>
Reviewed-by: David Gow <[email protected]>
Signed-off-by: David Gow <[email protected]>
---

Changes since v1:
https://lore.kernel.org/linux-kselftest/[email protected]/
 - Rebase on top of "kunit: tool: Add test for nested test result
   reporting"
   
https://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest.git/commit/?h=kunit&id=0c5b86c67fb6898d02c8f92de884186297fd302f

---
 tools/testing/kunit/kunit_tool_test.py | 56 +++++++++++++-------------
 1 file changed, 28 insertions(+), 28 deletions(-)

diff --git a/tools/testing/kunit/kunit_tool_test.py 
b/tools/testing/kunit/kunit_tool_test.py
index bdc51b5c7b10..30ac1cb6c8ed 100755
--- a/tools/testing/kunit/kunit_tool_test.py
+++ b/tools/testing/kunit/kunit_tool_test.py
@@ -36,7 +36,7 @@ def setUpModule():
 def tearDownModule():
        shutil.rmtree(test_tmpdir)
 
-def test_data_path(path):
+def _test_data_path(path):
        return os.path.join(abs_test_data_dir, path)
 
 class KconfigTest(unittest.TestCase):
@@ -52,7 +52,7 @@ class KconfigTest(unittest.TestCase):
                self.assertFalse(kconfig1.is_subset_of(kconfig0))
 
        def test_read_from_file(self):
-               kconfig_path = test_data_path('test_read_from_file.kconfig')
+               kconfig_path = _test_data_path('test_read_from_file.kconfig')
 
                kconfig = kunit_config.parse_file(kconfig_path)
 
@@ -98,7 +98,7 @@ class KUnitParserTest(unittest.TestCase):
                raise AssertionError(f'"{needle}" not found in {list(backup)}!')
 
        def test_output_isolated_correctly(self):
-               log_path = test_data_path('test_output_isolated_correctly.log')
+               log_path = _test_data_path('test_output_isolated_correctly.log')
                with open(log_path) as file:
                        result = 
kunit_parser.extract_tap_lines(file.readlines())
                self.assertContains('TAP version 14', result)
@@ -109,7 +109,7 @@ class KUnitParserTest(unittest.TestCase):
                self.assertContains('ok 1 - example', result)
 
        def test_output_with_prefix_isolated_correctly(self):
-               log_path = test_data_path('test_pound_sign.log')
+               log_path = _test_data_path('test_pound_sign.log')
                with open(log_path) as file:
                        result = 
kunit_parser.extract_tap_lines(file.readlines())
                self.assertContains('TAP version 14', result)
@@ -138,35 +138,35 @@ class KUnitParserTest(unittest.TestCase):
                self.assertContains('ok 3 - string-stream-test', result)
 
        def test_parse_successful_test_log(self):
-               all_passed_log = 
test_data_path('test_is_test_passed-all_passed.log')
+               all_passed_log = 
_test_data_path('test_is_test_passed-all_passed.log')
                with open(all_passed_log) as file:
                        result = kunit_parser.parse_run_tests(file.readlines(), 
stdout)
                self.assertEqual(kunit_parser.TestStatus.SUCCESS, result.status)
                self.assertEqual(result.counts.errors, 0)
 
        def test_parse_successful_nested_tests_log(self):
-               all_passed_log = 
test_data_path('test_is_test_passed-all_passed_nested.log')
+               all_passed_log = 
_test_data_path('test_is_test_passed-all_passed_nested.log')
                with open(all_passed_log) as file:
                        result = kunit_parser.parse_run_tests(file.readlines(), 
stdout)
                self.assertEqual(kunit_parser.TestStatus.SUCCESS, result.status)
                self.assertEqual(result.counts.errors, 0)
 
        def test_kselftest_nested(self):
-               kselftest_log = 
test_data_path('test_is_test_passed-kselftest.log')
+               kselftest_log = 
_test_data_path('test_is_test_passed-kselftest.log')
                with open(kselftest_log) as file:
                        result = kunit_parser.parse_run_tests(file.readlines(), 
stdout)
                self.assertEqual(kunit_parser.TestStatus.SUCCESS, result.status)
                self.assertEqual(result.counts.errors, 0)
 
        def test_parse_failed_test_log(self):
-               failed_log = test_data_path('test_is_test_passed-failure.log')
+               failed_log = _test_data_path('test_is_test_passed-failure.log')
                with open(failed_log) as file:
                        result = kunit_parser.parse_run_tests(file.readlines(), 
stdout)
                self.assertEqual(kunit_parser.TestStatus.FAILURE, result.status)
                self.assertEqual(result.counts.errors, 0)
 
        def test_parse_failed_nested_tests_log(self):
-               nested_log = 
test_data_path('test_is_test_passed-failure-nested.log')
+               nested_log = 
_test_data_path('test_is_test_passed-failure-nested.log')
                with open(nested_log) as file:
                        result = kunit_parser.parse_run_tests(file.readlines(), 
stdout)
                self.assertEqual(kunit_parser.TestStatus.FAILURE, result.status)
@@ -177,7 +177,7 @@ class KUnitParserTest(unittest.TestCase):
                self.assertEqual(kunit_parser.TestStatus.FAILURE, 
result.subtests[1].subtests[0].status)
 
        def test_no_header(self):
-               empty_log = 
test_data_path('test_is_test_passed-no_tests_run_no_header.log')
+               empty_log = 
_test_data_path('test_is_test_passed-no_tests_run_no_header.log')
                with open(empty_log) as file:
                        result = kunit_parser.parse_run_tests(
                                
kunit_parser.extract_tap_lines(file.readlines()), stdout)
@@ -186,7 +186,7 @@ class KUnitParserTest(unittest.TestCase):
                self.assertEqual(result.counts.errors, 1)
 
        def test_missing_test_plan(self):
-               missing_plan_log = test_data_path('test_is_test_passed-'
+               missing_plan_log = _test_data_path('test_is_test_passed-'
                        'missing_plan.log')
                with open(missing_plan_log) as file:
                        result = kunit_parser.parse_run_tests(
@@ -197,7 +197,7 @@ class KUnitParserTest(unittest.TestCase):
                self.assertEqual(kunit_parser.TestStatus.SUCCESS, result.status)
 
        def test_no_tests(self):
-               header_log = 
test_data_path('test_is_test_passed-no_tests_run_with_header.log')
+               header_log = 
_test_data_path('test_is_test_passed-no_tests_run_with_header.log')
                with open(header_log) as file:
                        result = kunit_parser.parse_run_tests(
                                
kunit_parser.extract_tap_lines(file.readlines()), stdout)
@@ -206,7 +206,7 @@ class KUnitParserTest(unittest.TestCase):
                self.assertEqual(result.counts.errors, 1)
 
        def test_no_tests_no_plan(self):
-               no_plan_log = 
test_data_path('test_is_test_passed-no_tests_no_plan.log')
+               no_plan_log = 
_test_data_path('test_is_test_passed-no_tests_no_plan.log')
                with open(no_plan_log) as file:
                        result = kunit_parser.parse_run_tests(
                                
kunit_parser.extract_tap_lines(file.readlines()), stdout)
@@ -218,7 +218,7 @@ class KUnitParserTest(unittest.TestCase):
 
 
        def test_no_kunit_output(self):
-               crash_log = test_data_path('test_insufficient_memory.log')
+               crash_log = _test_data_path('test_insufficient_memory.log')
                print_mock = mock.patch('kunit_printer.Printer.print').start()
                with open(crash_log) as file:
                        result = kunit_parser.parse_run_tests(
@@ -229,7 +229,7 @@ class KUnitParserTest(unittest.TestCase):
                self.assertEqual(result.counts.errors, 1)
 
        def test_skipped_test(self):
-               skipped_log = test_data_path('test_skip_tests.log')
+               skipped_log = _test_data_path('test_skip_tests.log')
                with open(skipped_log) as file:
                        result = kunit_parser.parse_run_tests(file.readlines(), 
stdout)
 
@@ -238,7 +238,7 @@ class KUnitParserTest(unittest.TestCase):
                self.assertEqual(result.counts, 
kunit_parser.TestCounts(passed=4, skipped=1))
 
        def test_skipped_all_tests(self):
-               skipped_log = test_data_path('test_skip_all_tests.log')
+               skipped_log = _test_data_path('test_skip_all_tests.log')
                with open(skipped_log) as file:
                        result = kunit_parser.parse_run_tests(file.readlines(), 
stdout)
 
@@ -246,7 +246,7 @@ class KUnitParserTest(unittest.TestCase):
                self.assertEqual(result.counts, 
kunit_parser.TestCounts(skipped=5))
 
        def test_ignores_hyphen(self):
-               hyphen_log = test_data_path('test_strip_hyphen.log')
+               hyphen_log = _test_data_path('test_strip_hyphen.log')
                with open(hyphen_log) as file:
                        result = kunit_parser.parse_run_tests(file.readlines(), 
stdout)
 
@@ -260,7 +260,7 @@ class KUnitParserTest(unittest.TestCase):
                        result.subtests[1].name)
 
        def test_ignores_prefix_printk_time(self):
-               prefix_log = test_data_path('test_config_printk_time.log')
+               prefix_log = _test_data_path('test_config_printk_time.log')
                with open(prefix_log) as file:
                        result = kunit_parser.parse_run_tests(file.readlines(), 
stdout)
                self.assertEqual(kunit_parser.TestStatus.SUCCESS, result.status)
@@ -268,7 +268,7 @@ class KUnitParserTest(unittest.TestCase):
                self.assertEqual(result.counts.errors, 0)
 
        def test_ignores_multiple_prefixes(self):
-               prefix_log = test_data_path('test_multiple_prefixes.log')
+               prefix_log = _test_data_path('test_multiple_prefixes.log')
                with open(prefix_log) as file:
                        result = kunit_parser.parse_run_tests(file.readlines(), 
stdout)
                self.assertEqual(kunit_parser.TestStatus.SUCCESS, result.status)
@@ -276,7 +276,7 @@ class KUnitParserTest(unittest.TestCase):
                self.assertEqual(result.counts.errors, 0)
 
        def test_prefix_mixed_kernel_output(self):
-               mixed_prefix_log = 
test_data_path('test_interrupted_tap_output.log')
+               mixed_prefix_log = 
_test_data_path('test_interrupted_tap_output.log')
                with open(mixed_prefix_log) as file:
                        result = kunit_parser.parse_run_tests(file.readlines(), 
stdout)
                self.assertEqual(kunit_parser.TestStatus.SUCCESS, result.status)
@@ -284,7 +284,7 @@ class KUnitParserTest(unittest.TestCase):
                self.assertEqual(result.counts.errors, 0)
 
        def test_prefix_poundsign(self):
-               pound_log = test_data_path('test_pound_sign.log')
+               pound_log = _test_data_path('test_pound_sign.log')
                with open(pound_log) as file:
                        result = kunit_parser.parse_run_tests(file.readlines(), 
stdout)
                self.assertEqual(kunit_parser.TestStatus.SUCCESS, result.status)
@@ -292,7 +292,7 @@ class KUnitParserTest(unittest.TestCase):
                self.assertEqual(result.counts.errors, 0)
 
        def test_kernel_panic_end(self):
-               panic_log = test_data_path('test_kernel_panic_interrupt.log')
+               panic_log = _test_data_path('test_kernel_panic_interrupt.log')
                with open(panic_log) as file:
                        result = kunit_parser.parse_run_tests(file.readlines(), 
stdout)
                self.assertEqual(kunit_parser.TestStatus.TEST_CRASHED, 
result.status)
@@ -300,7 +300,7 @@ class KUnitParserTest(unittest.TestCase):
                self.assertGreaterEqual(result.counts.errors, 1)
 
        def test_pound_no_prefix(self):
-               pound_log = test_data_path('test_pound_no_prefix.log')
+               pound_log = _test_data_path('test_pound_no_prefix.log')
                with open(pound_log) as file:
                        result = kunit_parser.parse_run_tests(file.readlines(), 
stdout)
                self.assertEqual(kunit_parser.TestStatus.SUCCESS, result.status)
@@ -329,7 +329,7 @@ class KUnitParserTest(unittest.TestCase):
                        'Failures: all_failed_suite, some_failed_suite.test2')
 
        def test_ktap_format(self):
-               ktap_log = test_data_path('test_parse_ktap_output.log')
+               ktap_log = _test_data_path('test_parse_ktap_output.log')
                with open(ktap_log) as file:
                        result = kunit_parser.parse_run_tests(file.readlines(), 
stdout)
                self.assertEqual(result.counts, 
kunit_parser.TestCounts(passed=3))
@@ -338,13 +338,13 @@ class KUnitParserTest(unittest.TestCase):
                self.assertEqual('case_2', result.subtests[0].subtests[1].name)
 
        def test_parse_subtest_header(self):
-               ktap_log = test_data_path('test_parse_subtest_header.log')
+               ktap_log = _test_data_path('test_parse_subtest_header.log')
                with open(ktap_log) as file:
                        kunit_parser.parse_run_tests(file.readlines(), stdout)
                self.print_mock.assert_any_call(StrContains('suite (1 
subtest)'))
 
        def test_parse_attributes(self):
-               ktap_log = test_data_path('test_parse_attributes.log')
+               ktap_log = _test_data_path('test_parse_attributes.log')
                with open(ktap_log) as file:
                        result = kunit_parser.parse_run_tests(file.readlines(), 
stdout)
 
@@ -566,7 +566,7 @@ class KUnitJsonTest(unittest.TestCase):
                self.addCleanup(mock.patch.stopall)
 
        def _json_for(self, log_file):
-               with open(test_data_path(log_file)) as file:
+               with open(_test_data_path(log_file)) as file:
                        test_result = kunit_parser.parse_run_tests(file, stdout)
                        json_obj = kunit_json.get_json_result(
                                test=test_result,
@@ -607,7 +607,7 @@ class StrContains(str):
 
 class KUnitMainTest(unittest.TestCase):
        def setUp(self):
-               path = test_data_path('test_is_test_passed-all_passed.log')
+               path = _test_data_path('test_is_test_passed-all_passed.log')
                with open(path) as file:
                        all_passed_log = file.readlines()
 
-- 
2.52.0.351.gbe84eed79e-goog


Reply via email to