[igt-dev] [PATCH i-g-t v2 05/19] scripts/igt_doc.py: improve --show-subtests logic
Zbigniew Kempczyński
zbigniew.kempczynski at intel.com
Mon Mar 13 06:54:22 UTC 2023
On Fri, Mar 10, 2023 at 08:41:11PM +0100, Zbigniew Kempczyński wrote:
> From: Mauro Carvalho Chehab <mchehab at kernel.org>
>
> Add command line parameters to improve --show-subtests:
> 1) to sort results of --show-subtest based on the contents of a field.
> This is useful, for instance, to check if all subtests have
> proper values for a given field.
> 2) to filter for an specific field value. This is interesting to be
> able to compare testlists with the expected documented test list.
>
> Signed-off-by: Mauro Carvalho Chehab <mchehab at kernel.org>
> ---
> scripts/igt_doc.py | 64 ++++++++++++++++++++++++++++++++++++++++------
> 1 file changed, 56 insertions(+), 8 deletions(-)
>
> diff --git a/scripts/igt_doc.py b/scripts/igt_doc.py
> index 643c7e7a7b..712e22c9d3 100755
> --- a/scripts/igt_doc.py
> +++ b/scripts/igt_doc.py
> @@ -1,5 +1,5 @@
> #!/usr/bin/env python3
> -# pylint: disable=C0301,R0902,R0914,R0912,R0915
> +# pylint: disable=C0301,R0902,R0914,R0912,R0915,R1702,C0302
> # SPDX-License-Identifier: (GPL-2.0 OR MIT)
>
> ## Copyright (C) 2023 Intel Corporation ##
> @@ -689,11 +689,27 @@ class TestList:
> # Subtest list methods
> #
>
> - def get_subtests(self):
> + def get_subtests(self, sort_field = None, filter_field_expr = None):
>
> """Return an array with all subtests"""
>
> - subtests = []
> + subtests = {}
> + subtests[""] = []
> +
> + if sort_field:
> + if sort_field.lower() not in self.field_list:
> + sys.exit(f"Field '{sort_field}' is not defined")
> + sort_field = self.field_list[sort_field.lower()]
> +
> + if filter_field_expr:
> + if not (match := re.match(r"(.*)=~\s*(.*)", filter_field_expr)):
> + sys.exit(f"Filter field {filter_field_expr} is not at <field> =~ <regex> syntax")
> +
> + field = match.group(1).strip().lower()
> + if field not in self.field_list:
> + sys.exit(f"Field '{field}' is not defined")
> + filter_field = self.field_list[field]
> + regex = re.compile("{0}".format(match.group(2).strip()), re.I) # pylint: disable=C0209
>
> for test in sorted(self.doc.keys()):
> fname = self.doc[test]["File"]
> @@ -702,10 +718,26 @@ class TestList:
> test_name = re.sub(r'\.[ch]', '', test_name)
> test_name = "igt@" + test_name
>
> - subtest_array = self.expand_subtest(fname, test_name, test)
> + subtest_array = self.expand_subtest(fname, test_name, test, True)
>
> for subtest in subtest_array:
> - subtests.append(subtest["Summary"])
> + if filter_field_expr:
> + if filter_field not in subtest:
> + continue
> + if not re.match(regex, subtest[filter_field]):
> + continue
> +
> + if sort_field:
> + if sort_field in subtest:
> + if subtest[sort_field] not in subtests:
> + subtests[subtest[sort_field]] = []
> +
> + subtests[subtest[sort_field]].append(subtest["Summary"])
> + else:
> + subtests[""].append(subtest["Summary"])
> +
> + else:
> + subtests[""].append(subtest["Summary"])
>
> return subtests
>
> @@ -716,7 +748,7 @@ class TestList:
>
> """Compare documented subtests with the IGT test list"""
>
> - doc_subtests = sorted(self.get_subtests())
> + doc_subtests = sorted(self.get_subtests()[""])
>
> for i in range(0, len(doc_subtests)): # pylint: disable=C0200
> doc_subtests[i] = re.sub(r'\<[^\>]+\>', r'\\d+', doc_subtests[i])
> @@ -990,6 +1022,10 @@ parser.add_argument("--to-json",
> help="Output test documentation in JSON format as TO_JSON file")
> parser.add_argument("--show-subtests", action="store_true",
> help="Shows the name of the documented subtests in alphabetical order.")
> +parser.add_argument("--sort-field",
> + help="modify --show-subtests to sort output based on SORT_FIELD value")
> +parser.add_argument("--filter-field",
> + help="modify --show-subtests to filter output based a regex given by FILTER_FIELD=~'regex'")
> parser.add_argument("--check-testlist", action="store_true",
> help="Compare documentation against IGT runner testlist.")
> parser.add_argument("--include-plan", action="store_true",
> @@ -1007,8 +1043,20 @@ tests = TestList(parse_args.config, parse_args.include_plan, parse_args.files)
> RUN = 0
> if parse_args.show_subtests:
> RUN = 1
> - for sub in tests.get_subtests():
> - print (sub)
> + if parse_args.sort_field:
> + test_subtests = tests.get_subtests(parse_args.sort_field, parse_args.filter_field)
> + for val_key in sorted(test_subtests.keys()):
> + if not test_subtests[val_key]:
> + continue
> + if val_key == "":
> + print("not defined:")
> + else:
> + print(f"{val_key}:")
> + for sub in test_subtests[val_key]:
> + print (f" {sub}")
> + else:
> + for sub in tests.get_subtests(parse_args.sort_field, parse_args.filter_field)[""]:
> + print (sub)
>
> if parse_args.check_testlist:
> RUN = 1
> --
> 2.34.1
>
Acked-by: Zbigniew Kempczyński <zbigniew.kempczynski at intel.com>
--
Zbigniew
More information about the igt-dev
mailing list