summaryrefslogtreecommitdiff
path: root/math/py-pandas/scripts/print_skipped.py
diff options
context:
space:
mode:
Diffstat (limited to 'math/py-pandas/scripts/print_skipped.py')
-rw-r--r--math/py-pandas/scripts/print_skipped.py51
1 files changed, 51 insertions, 0 deletions
diff --git a/math/py-pandas/scripts/print_skipped.py b/math/py-pandas/scripts/print_skipped.py
new file mode 100644
index 000000000000..9fb05df64bce
--- /dev/null
+++ b/math/py-pandas/scripts/print_skipped.py
@@ -0,0 +1,51 @@
+#!/usr/bin/env python
+
+import sys
+import math
+import xml.etree.ElementTree as et
+
+
+def parse_results(filename):
+ tree = et.parse(filename)
+ root = tree.getroot()
+ skipped = []
+
+ current_class = old_class = ''
+ i = 1
+ assert i - 1 == len(skipped)
+ for el in root.findall('testcase'):
+ cn = el.attrib['classname']
+ for sk in el.findall('skipped'):
+ old_class = current_class
+ current_class = cn
+ name = '{classname}.{name}'.format(classname=current_class,
+ name=el.attrib['name'])
+ msg = sk.attrib['message']
+ out = ''
+ if old_class != current_class:
+ ndigits = int(math.log(i, 10) + 1)
+ out += ('-' * (len(name + msg) + 4 + ndigits) + '\n') # 4 for : + space + # + space
+ out += '#{i} {name}: {msg}'.format(i=i, name=name, msg=msg)
+ skipped.append(out)
+ i += 1
+ assert i - 1 == len(skipped)
+ assert i - 1 == len(skipped)
+ assert len(skipped) == int(root.attrib['skip'])
+ return '\n'.join(skipped)
+
+
+def main(args):
+ print('SKIPPED TESTS:')
+ print(parse_results(args.filename))
+ return 0
+
+
+def parse_args():
+ import argparse
+ parser = argparse.ArgumentParser()
+ parser.add_argument('filename', help='XUnit file to parse')
+ return parser.parse_args()
+
+
+if __name__ == '__main__':
+ sys.exit(main(parse_args()))