[igt-dev] [PATCH i-g-t 1/3] scripts/test_list.py: allow ignoring uppercase on testlist read
Mauro Carvalho Chehab
mauro.chehab at linux.intel.com
Fri Oct 13 09:29:27 UTC 2023
From: Mauro Carvalho Chehab <mchehab at kernel.org>
There are some tests in KMS which uses uppercase names. Add a
config option on test_list.py json handler to allow parsing
testlist regular expressions on a case-insensitive way.
Signed-off-by: Mauro Carvalho Chehab <mchehab at kernel.org>
---
scripts/test_list.py | 12 ++++++++----
1 file changed, 8 insertions(+), 4 deletions(-)
diff --git a/scripts/test_list.py b/scripts/test_list.py
index c0462188ba8a..c75d15bfca73 100644
--- a/scripts/test_list.py
+++ b/scripts/test_list.py
@@ -321,6 +321,10 @@ class TestList:
self.props["Class"]["_properties_"]["level"] = 1
self.props["Class"]["_properties_"]["sublevel"] = sublevel_count[0] + 1
+ flags = 0
+ if self.config.get("case_insensitive_testlist", False):
+ flags |= re.IGNORECASE
+
# Remove non-multilevel items, as we're only interested on
# hierarchical item levels here
for field, item in self.props.items():
@@ -335,7 +339,7 @@ class TestList:
testlist = {}
for value in item["_properties_"]["testlists"]:
for name in value.keys():
- self.read_testlist(testlist, name, cfg_path + value[name])
+ self.read_testlist(testlist, name, cfg_path + value[name], flags)
item["_properties_"]["testlist"] = testlist
@@ -344,7 +348,7 @@ class TestList:
blocklist = {}
for value in item["_properties_"]["blocklists"]:
for name in value.keys():
- self.read_testlist(testlist, name, cfg_path + value[name])
+ self.read_testlist(testlist, name, cfg_path + value[name], flags)
item["_properties_"]["blocklist"] = blocklist
@@ -448,7 +452,7 @@ class TestList:
self.__add_field(key, sublevel, hierarchy_level, field[key])
- def read_testlist(self, testlist, name, filename):
+ def read_testlist(self, testlist, name, filename, flags):
base = r"^\s*({}[^\s\{}]+)(\S*)\s*(\#.*)?$"
regex = re.compile(base.format(self.main_name, self.subtest_separator))
@@ -462,7 +466,7 @@ class TestList:
subtest = match.group(2)
if not subtest.endswith("$"):
subtest += r"(\@.*)?$"
- testlist[name].append(re.compile(f"{test}{subtest}"))
+ testlist[name].append(re.compile(f"{test}{subtest}", flags))
def __filter_subtest(self, test, subtest, field_not_found_value):
--
2.41.0
More information about the igt-dev
mailing list