File: print_skipped.py

package info (click to toggle)
pandas 0.23.3%2Bdfsg-3
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 167,704 kB
  • sloc: python: 230,826; ansic: 11,317; sh: 682; makefile: 133
file content (52 lines) | stat: -rwxr-xr-x 1,496 bytes parent folder | download
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
#!/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:')
    for fn in args.filename:
        print(parse_results(fn))
    return 0


def parse_args():
    import argparse
    parser = argparse.ArgumentParser()
    parser.add_argument('filename', nargs='+', help='XUnit file to parse')
    return parser.parse_args()


if __name__ == '__main__':
    sys.exit(main(parse_args()))