1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96
|
# Copyright (C) 2022 The Qt Company Ltd.
# SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
from __future__ import annotations
"""
testing/blacklist.py
Take a blacklist file and build classifiers for all tests.
find_matching_line() adds info using classifiers.
"""
from io import StringIO
from .buildlog import builds
from .helper import decorate
class BlackList:
def __init__(self, blname):
if not blname:
f = StringIO()
self.raw_data = []
else:
with open(blname) as f:
self.raw_data = f.readlines()
# keep all lines, but see what is not relevant
lines = self.raw_data[:]
def filtered_line(line):
if "#" in line:
line = line[:line.index("#")]
return line.split()
# now put every bracketed line in a test
# and use subsequent identifiers for a match
def is_test(fline):
return fline and fline[0].startswith("[")
self.tests = {}
if not lines:
# nothing supplied
return
for idx, line in enumerate(lines):
fline = filtered_line(line)
if not fline:
continue
if is_test(fline):
break
# we have a global section
name = ""
self.tests[name] = []
for idx, line in enumerate(lines):
fline = filtered_line(line)
if is_test(fline):
# a new name
name = decorate(fline[0][1:-1])
# Allow for repeated sections
self.tests.setdefault(name, [])
elif fline:
# a known name with a new entry
self.tests[name].append(fline)
def find_matching_line(self, test):
"""
Take a test result.
Find a line in the according blacklist file where all keys of the line are found.
If line not found, do nothing.
if line found and test passed, it is a BPASS.
If line found and test failed, it is a BFAIL.
"""
classifiers = set(builds.classifiers)
if "" in self.tests:
# this is a global section
for line in self.tests[""]:
keys = set(line)
if keys <= classifiers:
# found a match!
return line
mod_name = test.mod_name
if mod_name not in self.tests and decorate(mod_name) not in self.tests:
return None
if mod_name in self.tests:
thing = mod_name
else:
thing = decorate(mod_name)
for line in self.tests[thing]:
keys = set(line)
if keys <= classifiers:
# found a match!
return line
else:
return None # nothing found
|