◆ _new_backslashreplace_errors()
| def GaudiTesting.BaseTest._new_backslashreplace_errors |
( |
|
exc | ) |
|
|
private |
Definition at line 37 of file BaseTest.py.
38 if isinstance(exc, UnicodeDecodeError):
39 code =
hex(ord(exc.object[exc.start]))
40 return (
"\\" + code[1:], exc.start + 1)
42 return backslashreplace_errors(exc)
◆ _parseTTreeSummary()
| def GaudiTesting.BaseTest._parseTTreeSummary |
( |
|
lines, |
|
|
|
pos |
|
) |
| |
|
private |
Parse the TTree summary table in lines, starting from pos.
Returns a tuple with the dictionary with the digested informations and the
position of the first line after the summary.
Definition at line 1227 of file BaseTest.py.
1229 Parse the TTree summary table in lines, starting from pos.
1230 Returns a tuple with the dictionary with the digested informations and the
1231 position of the first line after the summary.
1238 return [f.strip()
for f
in l.strip(
"*\n").split(
":", 2)]
1242 cols = splitcols(ll[0])
1243 r[
"Name"], r[
"Title"] = cols[1:]
1245 cols = splitcols(ll[1])
1246 r[
"Entries"] = int(cols[1])
1248 sizes = cols[2].split()
1249 r[
"Total size"] = int(sizes[2])
1250 if sizes[-1] ==
"memory":
1253 r[
"File size"] = int(sizes[-1])
1255 cols = splitcols(ll[2])
1256 sizes = cols[2].split()
1257 if cols[0] ==
"Baskets":
1258 r[
"Baskets"] = int(cols[1])
1259 r[
"Basket size"] = int(sizes[2])
1260 r[
"Compression"] = float(sizes[-1])
1263 if i < (count - 3)
and lines[i].startswith(
"*Tree"):
1264 result = parseblock(lines[i : i + 3])
1265 result[
"Branches"] = {}
1267 while i < (count - 3)
and lines[i].startswith(
"*Br"):
1268 if i < (count - 2)
and lines[i].startswith(
"*Branch "):
1272 branch = parseblock(lines[i : i + 3])
1273 result[
"Branches"][branch[
"Name"]] = branch
◆ cmpTreesDicts()
| def GaudiTesting.BaseTest.cmpTreesDicts |
( |
|
reference, |
|
|
|
to_check, |
|
|
|
ignore = None |
|
) |
| |
Check that all the keys in reference are in to_check too, with the same value.
If the value is a dict, the function is called recursively. to_check can
contain more keys than reference, that will not be tested.
The function returns at the first difference found.
Definition at line 1179 of file BaseTest.py.
1181 Check that all the keys in reference are in to_check too, with the same value.
1182 If the value is a dict, the function is called recursively. to_check can
1183 contain more keys than reference, that will not be tested.
1184 The function returns at the first difference found.
1189 ignore_re = re.compile(ignore)
1190 keys = [key
for key
in reference
if not ignore_re.match(key)]
1192 keys = reference.keys()
1196 if (
type(reference[k])
is dict)
and (
type(to_check[k])
is dict):
1199 failed = fail_keys =
cmpTreesDicts(reference[k], to_check[k], ignore)
1202 failed = to_check[k] != reference[k]
1207 fail_keys.insert(0, k)
◆ dumpProcs()
| def GaudiTesting.BaseTest.dumpProcs |
( |
|
name | ) |
|
helper to debug GAUDI-1084, dump the list of processes
Definition at line 69 of file BaseTest.py.
70 """helper to debug GAUDI-1084, dump the list of processes"""
71 from getpass
import getuser
73 if "WORKSPACE" in os.environ:
74 p = Popen([
"ps",
"-fH",
"-U", getuser()], stdout=PIPE)
75 with open(os.path.join(os.environ[
"WORKSPACE"], name),
"wb")
as f:
76 f.write(p.communicate()[0])
◆ findHistosSummaries()
| def GaudiTesting.BaseTest.findHistosSummaries |
( |
|
stdout | ) |
|
Scan stdout to find ROOT TTree summaries and digest them.
Definition at line 1347 of file BaseTest.py.
1349 Scan stdout to find ROOT TTree summaries and digest them.
1351 outlines = stdout.splitlines()
1352 nlines = len(outlines) - 1
1360 match = h_count_re.search(outlines[pos])
1361 while pos < nlines
and not match:
1363 match = h_count_re.search(outlines[pos])
1366 summaries.update(summ)
◆ findTTreeSummaries()
| def GaudiTesting.BaseTest.findTTreeSummaries |
( |
|
stdout | ) |
|
Scan stdout to find ROOT TTree summaries and digest them.
Definition at line 1157 of file BaseTest.py.
1159 Scan stdout to find ROOT TTree summaries and digest them.
1161 stars = re.compile(
r"^\*+$")
1162 outlines = stdout.splitlines()
1163 nlines = len(outlines)
1169 while i < nlines
and not stars.match(outlines[i]):
1174 trees[tree[
"Name"]] = tree
◆ getCmpFailingValues()
| def GaudiTesting.BaseTest.getCmpFailingValues |
( |
|
reference, |
|
|
|
to_check, |
|
|
|
fail_path |
|
) |
| |
Definition at line 1212 of file BaseTest.py.
1218 if c
is None or r
is None:
1220 return (fail_path, r, c)
◆ GetPlatform()
| def GaudiTesting.BaseTest.GetPlatform |
( |
|
self | ) |
|
Return the platform Id defined in CMTCONFIG or SCRAM_ARCH.
Definition at line 1370 of file BaseTest.py.
1372 Return the platform Id defined in CMTCONFIG or SCRAM_ARCH.
1376 if "BINARY_TAG" in os.environ:
1377 arch = os.environ[
"BINARY_TAG"]
1378 elif "CMTCONFIG" in os.environ:
1379 arch = os.environ[
"CMTCONFIG"]
1380 elif "SCRAM_ARCH" in os.environ:
1381 arch = os.environ[
"SCRAM_ARCH"]
1382 elif os.environ.get(
"ENV_CMAKE_BUILD_TYPE",
"")
in (
1388 elif os.environ.get(
"ENV_CMAKE_BUILD_TYPE",
"")
in (
◆ isWinPlatform()
| def GaudiTesting.BaseTest.isWinPlatform |
( |
|
self | ) |
|
Return True if the current platform is Windows.
This function was needed because of the change in the CMTCONFIG format,
from win32_vc71_dbg to i686-winxp-vc9-dbg.
Definition at line 1398 of file BaseTest.py.
1400 Return True if the current platform is Windows.
1402 This function was needed because of the change in the CMTCONFIG format,
1403 from win32_vc71_dbg to i686-winxp-vc9-dbg.
1406 return "winxp" in platform
or platform.startswith(
"win")
◆ kill_tree()
| def GaudiTesting.BaseTest.kill_tree |
( |
|
ppid, |
|
|
|
sig |
|
) |
| |
Send a signal to a process and all its child processes (starting from the
leaves).
Definition at line 79 of file BaseTest.py.
81 Send a signal to a process and all its child processes (starting from the
84 log = logging.getLogger(
"kill_tree")
85 ps_cmd = [
"ps",
"--no-headers",
"-o",
"pid",
"--ppid", str(ppid)]
86 get_children = Popen(ps_cmd, stdout=PIPE, stderr=PIPE)
87 children =
map(int, get_children.communicate()[0].split())
88 for child
in children:
91 log.debug(
"killing process %d", ppid)
93 except OSError
as err:
96 log.debug(
"no such process %d", ppid)
◆ parseHistosSummary()
| def GaudiTesting.BaseTest.parseHistosSummary |
( |
|
lines, |
|
|
|
pos |
|
) |
| |
Extract the histograms infos from the lines starting at pos.
Returns the position of the first line after the summary block.
Definition at line 1279 of file BaseTest.py.
1281 Extract the histograms infos from the lines starting at pos.
1282 Returns the position of the first line after the summary block.
1285 h_table_head = re.compile(
1286 r'SUCCESS\s+(1D|2D|3D|1D profile|2D profile) histograms in directory\s+"(\w*)"'
1288 h_short_summ = re.compile(
r"ID=([^\"]+)\s+\"([^\"]+)\"\s+(.*)")
1293 m = h_count_re.search(lines[pos])
1294 name = m.group(1).strip()
1295 total = int(m.group(2))
1297 for k, v
in [x.split(
"=")
for x
in m.group(3).split()]:
1300 header[
"Total"] = total
1304 m = h_table_head.search(lines[pos])
1307 t = t.replace(
" profile",
"Prof")
1314 if l.startswith(
" | ID"):
1316 titles = [x.strip()
for x
in l.split(
"|")][1:]
1318 while pos < nlines
and lines[pos].startswith(
" |"):
1320 values = [x.strip()
for x
in l.split(
"|")][1:]
1322 for i
in range(len(titles)):
1323 hcont[titles[i]] = values[i]
1324 cont[hcont[
"ID"]] = hcont
1326 elif l.startswith(
" ID="):
1327 while pos < nlines
and lines[pos].startswith(
" ID="):
1329 x.strip()
for x
in h_short_summ.search(lines[pos]).groups()
1331 cont[values[0]] = values
1334 raise RuntimeError(
"Cannot understand line %d: '%s'" % (pos, l))
1338 summ[d][
"header"] = header
1343 summ[name] = {
"header": header}
◆ RationalizePath()
| def GaudiTesting.BaseTest.RationalizePath |
( |
|
p | ) |
|
Function used to normalize the used path
Definition at line 679 of file BaseTest.py.
681 Function used to normalize the used path
683 newPath = os.path.normpath(os.path.expandvars(p))
684 if os.path.exists(newPath):
685 p = os.path.realpath(newPath)
◆ ROOT6WorkAroundEnabled()
| def GaudiTesting.BaseTest.ROOT6WorkAroundEnabled |
( |
|
id = None | ) |
|
◆ sanitize_for_xml()
| def GaudiTesting.BaseTest.sanitize_for_xml |
( |
|
data | ) |
|
Take a string with invalid ASCII/UTF characters and quote them so that the
string can be used in an XML text.
>>> sanitize_for_xml('this is \x1b')
'this is [NON-XML-CHAR-0x1B]'
Definition at line 52 of file BaseTest.py.
54 Take a string with invalid ASCII/UTF characters and quote them so that the
55 string can be used in an XML text.
57 >>> sanitize_for_xml('this is \x1b')
58 'this is [NON-XML-CHAR-0x1B]'
60 bad_chars = re.compile(
"[\x00-\x08\x0b\x0c\x0e-\x1F\uD800-\uDFFF\uFFFE\uFFFF]")
64 return "".join(
"[NON-XML-CHAR-0x%2X]" % ord(c)
for c
in match.group())
66 return bad_chars.sub(quote, data)
◆ which()
| def GaudiTesting.BaseTest.which |
( |
|
executable | ) |
|
Locates an executable in the executables path ($PATH) and returns the full
path to it. An application is looked for with or without the '.exe' suffix.
If the executable cannot be found, None is returned
Definition at line 689 of file BaseTest.py.
689 def which(executable):
691 Locates an executable in the executables path ($PATH) and returns the full
692 path to it. An application is looked for with or without the '.exe' suffix.
693 If the executable cannot be found, None is returned
695 if os.path.isabs(executable):
696 if not os.path.isfile(executable):
697 if executable.endswith(
".exe"):
698 if os.path.isfile(executable[:-4]):
699 return executable[:-4]
701 executable = os.path.split(executable)[1]
704 for d
in os.environ.get(
"PATH").split(os.pathsep):
705 fullpath = os.path.join(d, executable)
706 if os.path.isfile(fullpath):
708 elif executable.endswith(
".exe")
and os.path.isfile(fullpath[:-4]):
◆ __processLine__
| GaudiTesting.BaseTest.__processLine__ |
|
private |
◆ h_count_re
| GaudiTesting.BaseTest.h_count_re = re.compile(r"^(.*)SUCCESS\s+Booked (\d+) Histogram\(s\) :\s+([\s\w=-]*)") |
◆ lineSkipper
| GaudiTesting.BaseTest.lineSkipper |
◆ maskPointers
| GaudiTesting.BaseTest.maskPointers = RegexpReplacer("0x[0-9a-fA-F]{4,16}", "0x########") |
◆ normalizeDate
| GaudiTesting.BaseTest.normalizeDate |
Initial value:
2 "[0-2]?[0-9]:[0-5][0-9]:[0-5][0-9] [0-9]{4}[-/][01][0-9][-/][0-3][0-9][ A-Z]*",
Definition at line 912 of file BaseTest.py.
◆ normalizeEOL
◆ normalizeExamples
◆ regexps
| GaudiTesting.BaseTest.regexps |
◆ SKIP_RETURN_CODE
| int GaudiTesting.BaseTest.SKIP_RETURN_CODE = 77 |
◆ skipEmptyLines
MsgStream & hex(MsgStream &log)
def _parseTTreeSummary(lines, pos)
def sanitize_for_xml(data)
def getCmpFailingValues(reference, to_check, fail_path)
def _new_backslashreplace_errors(exc)
struct GAUDI_API map
Parametrisation class for map-like implementation.
def parseHistosSummary(lines, pos)
def cmpTreesDicts(reference, to_check, ignore=None)
def findHistosSummaries(stdout)
def findTTreeSummaries(stdout)
def ROOT6WorkAroundEnabled(id=None)
decltype(auto) range(Args &&... args)
Zips multiple containers together to form a single range.