1#!/usr/bin/env python 2# 3# Script for determining items missing from LTP install based on the output 4# log provided by runltp[lite.sh]. 5# 6# Copyright (C) 2009, Cisco Systems Inc. 7# 8# This program is free software; you can redistribute it and/or modify 9# it under the terms of the GNU General Public License as published by 10# the Free Software Foundation; either version 2 of the License, or 11# (at your option) any later version. 12# 13# This program is distributed in the hope that it will be useful, 14# but WITHOUT ANY WARRANTY; without even the implied warranty of 15# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 16# GNU General Public License for more details. 17# 18# You should have received a copy of the GNU General Public License along 19# with this program; if not, write to the Free Software Foundation, Inc., 20# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. 21# 22# Garrett Cooper, July 2009 23# 24# Please invoke this script with --help to determine usage. 25# 26 27from optparse import OptionParser 28import os, re, sys 29 30parser = OptionParser(usage='usage: %prog [options] logfile ...') 31 32parser.add_option('-v', '--verbose', action='store_true', default=False, 33 dest='verbose', help=('print out successful results as ' 34 'well as failures')) 35 36opts, logfiles = parser.parse_args() 37 38if not len(logfiles): 39 parser.print_help() 40 41for logfile in logfiles: 42 if not os.access(logfile, os.R_OK): 43 sys.exit("%s not readable" % logfile) 44 45todo_res = [ 46 re.compile("""initiation_status="pan\(\d+\): execvp of '(?P<app>.+)' \(tag (?P<tag>\w+)\) failed.+errno:2\s+No such file or directory"""), 47 re.compile("(?P<tag>\S+): line \d+: (?P<app>\S+): No such file or directory"), 48 re.compile("(?P<caller>\S+): (?P<app>\s+): No such file or directory"), 49 re.compile("""tag=(?P<tag>\w+) [\w=]+ 50cmdline=.+ 51contacts=.+ 52analysis=.+ 53<<<test_output>>> 54(\S+): (?P<app>\w+): command not found 55<<<execution_status>>> 56initiation_status=.+ 57.+termination_id=127.+""") 58] 59 60for logfile in logfiles: 61 fd = open(logfile) 62 63 # Case 1: 64 65 # initiation_status="pan(9908): execvp of 'fs_perms_simpletest.sh' (tag fs_perms) failed. errno:2 No such file or directory" 66 67 # Case 2: 68 69 # /scratch/ltp-install4/testcases/bin/test_controllers.sh: line 109: /scratch/ltp-install4/testcases/bin/run_cpuset_test.sh: No such file or directory 70 71 # Case 3: 72 73 # gcc: /scratch/ltp-install4/testcases/bin/nmfile2.c: No such file or directory 74 75 # Case 4: 76 77 # <<<test_start>>> 78 # tag=iogen01 stime=1248638309 79 # cmdline="export LTPROOT; rwtest -N iogen01 -i 120s -s read,write -Da -Dv -n 2 500b:doio.f1.$$ 1000b:doio.f2.$$" 80 # contacts="" 81 # analysis=exit 82 # <<<test_output>>> 83 # sh: rwtest: command not found 84 # <<<execution_status>>> 85 # initiation_status="ok" 86 # duration=0 termination_type=exited termination_id=127 corefile=no 87 88 missing_ents = [] 89 90 try: 91 92 lines = fd.readlines() 93 94 for line in lines: 95 96 for todo_re in todo_res[:-1]: 97 98 m = todo_re.match(line) 99 if m: 100 missing_ent = " ".join([m.group(1), m.group('app')]) 101 if missing_ent not in missing_ents: 102 missing_ents.append(missing_ent) 103 break 104 105 for m in todo_res[2].finditer("".join(lines)): 106 missing_ent = " ".join([m.group('tag'), m.group('app')]) 107 if missing_ent not in missing_ents: 108 missing_ents.append(missing_ent) 109 110 finally: 111 fd.close() 112 113 if len(missing_ents): 114 print "\n".join(["%s: %s" % (os.path.basename(logfile), i) for i in ["Tag | App"] + missing_ents]) 115 elif opts.verbose: 116 print "%s: CONGRATULATIONS -- no missing files found!" % os.path.basename(logfile) 117