aboutsummaryrefslogtreecommitdiff
path: root/automated/linux/igt/print-test-result.py
blob: 42a939d427522b86beded8a406afb75767594e93 (plain)
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
#!/usr/bin/python
import argparse
import sys
import json


def print_result(results):
    for test, content in results['tests'].iteritems():
        content = {k: unicode(v).encode("utf-8") for k, v in content.iteritems()}
        print '<LAVA_SIGNAL_STARTTC %s>' % test
        print '************************************************************************************************************************************'
        print '%-15s %s' % ('Test:', test)
        print '%-15s %s' % ('Result:', content['result'])
        # Test result generated by igt_runner doesn't have the following values
        try:
            print '%-15s %s' % ('Command:', content['command'])
            print '%-15s %s' % ('Environment:', content['environment'])
            print '%-15s %s' % ('Returncode:', content['returncode'])
        except KeyError:
            pass
        print '%-15s %s' % ('Stdout:', content['out'].replace('\n', '\n                '))
        print '%-15s %s' % ('Stderr:', content['err'].replace('\n', '\n                '))
        print '%-15s %s' % ('dmesg:', content['dmesg'].replace('\n', '\n                '))
        print '<LAVA_SIGNAL_TESTCASE TEST_CASE_ID=%s RESULT=%s>' % (test, content['result'])
        print '<LAVA_SIGNAL_ENDTC %s>' % test


if __name__ == '__main__':
    parser = argparse.ArgumentParser()
    parser.add_argument("-f",
                        "--json-file",
                        nargs='?',
                        default=sys.stdin,
                        type=argparse.FileType('r'),
                        help="Test result file in json format")

    args = parser.parse_args()
    with args.json_file as data:
        results = json.load(data)

    print_result(results)