lmr | b635b86 | 2009-09-10 14:53:21 +0000 | [diff] [blame] | 1 | #!/usr/bin/python |
lmr | 6f669ce | 2009-05-31 19:02:42 +0000 | [diff] [blame] | 2 | """ |
| 3 | Program that parses the autotest results and return a nicely printed final test |
| 4 | result. |
| 5 | |
| 6 | @copyright: Red Hat 2008-2009 |
| 7 | """ |
| 8 | |
| 9 | def parse_results(text): |
lmr | b635b86 | 2009-09-10 14:53:21 +0000 | [diff] [blame] | 10 | """ |
| 11 | Parse text containing Autotest results. |
| 12 | |
| 13 | @return: A list of result 4-tuples. |
| 14 | """ |
lmr | 6f669ce | 2009-05-31 19:02:42 +0000 | [diff] [blame] | 15 | result_list = [] |
| 16 | start_time_list = [] |
| 17 | info_list = [] |
| 18 | |
| 19 | lines = text.splitlines() |
| 20 | for line in lines: |
| 21 | line = line.strip() |
| 22 | parts = line.split("\t") |
| 23 | |
| 24 | # Found a START line -- get start time |
lmr | b635b86 | 2009-09-10 14:53:21 +0000 | [diff] [blame] | 25 | if (line.startswith("START") and len(parts) >= 5 and |
| 26 | parts[3].startswith("timestamp")): |
lmr | 80460ce | 2010-05-17 20:55:02 +0000 | [diff] [blame^] | 27 | start_time = float(parts[3].split("=")[1]) |
lmr | 6f669ce | 2009-05-31 19:02:42 +0000 | [diff] [blame] | 28 | start_time_list.append(start_time) |
| 29 | info_list.append("") |
| 30 | |
| 31 | # Found an END line -- get end time, name and status |
lmr | b635b86 | 2009-09-10 14:53:21 +0000 | [diff] [blame] | 32 | elif (line.startswith("END") and len(parts) >= 5 and |
| 33 | parts[3].startswith("timestamp")): |
lmr | 80460ce | 2010-05-17 20:55:02 +0000 | [diff] [blame^] | 34 | end_time = float(parts[3].split("=")[1]) |
lmr | 6f669ce | 2009-05-31 19:02:42 +0000 | [diff] [blame] | 35 | start_time = start_time_list.pop() |
| 36 | info = info_list.pop() |
| 37 | test_name = parts[2] |
| 38 | test_status = parts[0].split()[1] |
lmr | 80460ce | 2010-05-17 20:55:02 +0000 | [diff] [blame^] | 39 | # Remove "kvm." prefix |
lmr | fc0e141 | 2009-06-10 20:03:26 +0000 | [diff] [blame] | 40 | if test_name.startswith("kvm."): |
| 41 | test_name = test_name.split("kvm.")[1] |
lmr | b635b86 | 2009-09-10 14:53:21 +0000 | [diff] [blame] | 42 | result_list.append((test_name, test_status, |
| 43 | int(end_time - start_time), info)) |
lmr | 6f669ce | 2009-05-31 19:02:42 +0000 | [diff] [blame] | 44 | |
| 45 | # Found a FAIL/ERROR/GOOD line -- get failure/success info |
lmr | b635b86 | 2009-09-10 14:53:21 +0000 | [diff] [blame] | 46 | elif (len(parts) >= 6 and parts[3].startswith("timestamp") and |
| 47 | parts[4].startswith("localtime")): |
lmr | 6f669ce | 2009-05-31 19:02:42 +0000 | [diff] [blame] | 48 | info_list[-1] = parts[5] |
| 49 | |
| 50 | return result_list |
| 51 | |
| 52 | |
lmr | 80460ce | 2010-05-17 20:55:02 +0000 | [diff] [blame^] | 53 | def print_result(result, name_width): |
| 54 | """ |
| 55 | Nicely print a single Autotest result. |
lmr | 6f669ce | 2009-05-31 19:02:42 +0000 | [diff] [blame] | 56 | |
lmr | 80460ce | 2010-05-17 20:55:02 +0000 | [diff] [blame^] | 57 | @param result: a 4-tuple |
| 58 | @param name_width: test name maximum width |
lmr | 6f669ce | 2009-05-31 19:02:42 +0000 | [diff] [blame] | 59 | """ |
| 60 | if result: |
lmr | 80460ce | 2010-05-17 20:55:02 +0000 | [diff] [blame^] | 61 | format = "%%-%ds %%-10s %%-8s %%s" % name_width |
| 62 | print format % result |
lmr | 6f669ce | 2009-05-31 19:02:42 +0000 | [diff] [blame] | 63 | |
| 64 | |
lmr | 9fb4827 | 2009-09-09 22:04:53 +0000 | [diff] [blame] | 65 | def main(resfiles): |
lmr | 80460ce | 2010-05-17 20:55:02 +0000 | [diff] [blame^] | 66 | result_lists = [] |
| 67 | name_width = 40 |
lmr | 6f669ce | 2009-05-31 19:02:42 +0000 | [diff] [blame] | 68 | |
lmr | 9fb4827 | 2009-09-09 22:04:53 +0000 | [diff] [blame] | 69 | for resfile in resfiles: |
lmr | 9fb4827 | 2009-09-09 22:04:53 +0000 | [diff] [blame] | 70 | try: |
lmr | 80460ce | 2010-05-17 20:55:02 +0000 | [diff] [blame^] | 71 | text = open(resfile).read() |
lmr | 9fb4827 | 2009-09-09 22:04:53 +0000 | [diff] [blame] | 72 | except IOError: |
lmr | 80460ce | 2010-05-17 20:55:02 +0000 | [diff] [blame^] | 73 | print "Bad result file: %s" % resfile |
| 74 | continue |
lmr | 9fb4827 | 2009-09-09 22:04:53 +0000 | [diff] [blame] | 75 | results = parse_results(text) |
lmr | 80460ce | 2010-05-17 20:55:02 +0000 | [diff] [blame^] | 76 | result_lists.append((resfile, results)) |
| 77 | name_width = max(name_width, max(len(r[0]) for r in results)) |
| 78 | |
| 79 | print_result(("Test", "Status", "Seconds", "Info"), name_width) |
| 80 | print_result(("----", "------", "-------", "----"), name_width) |
| 81 | |
| 82 | for resfile, results in result_lists: |
| 83 | print " (Result file: %s)" % resfile |
| 84 | for r in results: |
| 85 | print_result(r, name_width) |
lmr | 6f669ce | 2009-05-31 19:02:42 +0000 | [diff] [blame] | 86 | |
| 87 | |
lmr | 80460ce | 2010-05-17 20:55:02 +0000 | [diff] [blame^] | 88 | if __name__ == "__main__": |
lmr | 9fb4827 | 2009-09-09 22:04:53 +0000 | [diff] [blame] | 89 | import sys, os, glob |
lmr | 6f669ce | 2009-05-31 19:02:42 +0000 | [diff] [blame] | 90 | |
lmr | 80460ce | 2010-05-17 20:55:02 +0000 | [diff] [blame^] | 91 | resfiles = glob.glob("../../results/default/status*") |
lmr | 9fb4827 | 2009-09-09 22:04:53 +0000 | [diff] [blame] | 92 | if len(sys.argv) > 1: |
lmr | 80460ce | 2010-05-17 20:55:02 +0000 | [diff] [blame^] | 93 | if sys.argv[1] == "-h" or sys.argv[1] == "--help": |
| 94 | print "Usage: %s [result files]" % sys.argv[0] |
lmr | 9fb4827 | 2009-09-09 22:04:53 +0000 | [diff] [blame] | 95 | sys.exit(0) |
| 96 | resfiles = sys.argv[1:] |
| 97 | main(resfiles) |