d65d07cb5b
Update to kunit_parser to improve compatibility with KTAP specification including arbitrarily nested tests. Patch accomplishes three major changes: - Use a general Test object to represent all tests rather than TestCase and TestSuite objects. This allows for easier implementation of arbitrary levels of nested tests and promotes the idea that both test suites and test cases are tests. - Print errors incrementally rather than all at once after the parsing finishes to maximize information given to the user in the case of the parser given invalid input and to increase the helpfulness of the timestamps given during printing. Note that kunit.py parse does not print incrementally yet. However, this fix brings us closer to this feature. - Increase compatibility for different formats of input. Arbitrary levels of nested tests supported. Also, test cases and test suites are now supported to be present on the same level of testing. This patch now implements the draft KTAP specification here: https://lore.kernel.org/linux-kselftest/CA+GJov6tdjvY9x12JsJT14qn6c7NViJxqaJk+r-K1YJzPggFDQ@mail.gmail.com/ We'll update the parser as the spec evolves. This patch adjusts the kunit_tool_test.py file to check for the correct outputs from the new parser and adds a new test to check the parsing for a KTAP result log with correct format for multiple nested subtests (test_is_test_passed-all_passed_nested.log). This patch also alters the kunit_json.py file to allow for arbitrarily nested tests. Signed-off-by: Rae Moar <rmoar@google.com> Reviewed-by: Brendan Higgins <brendanhiggins@google.com> Signed-off-by: Daniel Latypov <dlatypov@google.com> Reviewed-by: David Gow <davidgow@google.com> Signed-off-by: Shuah Khan <skhan@linuxfoundation.org>
64 lines
1.8 KiB
Python
64 lines
1.8 KiB
Python
# SPDX-License-Identifier: GPL-2.0
|
|
#
|
|
# Generates JSON from KUnit results according to
|
|
# KernelCI spec: https://github.com/kernelci/kernelci-doc/wiki/Test-API
|
|
#
|
|
# Copyright (C) 2020, Google LLC.
|
|
# Author: Heidi Fahim <heidifahim@google.com>
|
|
|
|
import json
|
|
import os
|
|
|
|
import kunit_parser
|
|
|
|
from kunit_parser import Test, TestResult, TestStatus
|
|
from typing import Any, Dict, Optional
|
|
|
|
JsonObj = Dict[str, Any]
|
|
|
|
def _get_group_json(test: Test, def_config: str,
|
|
build_dir: Optional[str]) -> JsonObj:
|
|
sub_groups = [] # List[JsonObj]
|
|
test_cases = [] # List[JsonObj]
|
|
|
|
for subtest in test.subtests:
|
|
if len(subtest.subtests):
|
|
sub_group = _get_group_json(subtest, def_config,
|
|
build_dir)
|
|
sub_groups.append(sub_group)
|
|
else:
|
|
test_case = {"name": subtest.name, "status": "FAIL"}
|
|
if subtest.status == TestStatus.SUCCESS:
|
|
test_case["status"] = "PASS"
|
|
elif subtest.status == TestStatus.TEST_CRASHED:
|
|
test_case["status"] = "ERROR"
|
|
test_cases.append(test_case)
|
|
|
|
test_group = {
|
|
"name": test.name,
|
|
"arch": "UM",
|
|
"defconfig": def_config,
|
|
"build_environment": build_dir,
|
|
"sub_groups": sub_groups,
|
|
"test_cases": test_cases,
|
|
"lab_name": None,
|
|
"kernel": None,
|
|
"job": None,
|
|
"git_branch": "kselftest",
|
|
}
|
|
return test_group
|
|
|
|
def get_json_result(test_result: TestResult, def_config: str,
|
|
build_dir: Optional[str], json_path: str) -> str:
|
|
test_group = _get_group_json(test_result.test, def_config, build_dir)
|
|
test_group["name"] = "KUnit Test Group"
|
|
json_obj = json.dumps(test_group, indent=4)
|
|
if json_path != 'stdout':
|
|
with open(json_path, 'w') as result_path:
|
|
result_path.write(json_obj)
|
|
root = __file__.split('tools/testing/kunit/')[0]
|
|
kunit_parser.print_with_timestamp(
|
|
"Test results stored in %s" %
|
|
os.path.join(root, result_path.name))
|
|
return json_obj
|