source: icGREP/icgrep-devel/QA/greptest.py @ 4126

Last change on this file since 4126 was 4126, checked in by linmengl, 5 years ago

initial checkin of performance script; based on Ben's script, will do correctness check first and record performance data in json format. A python script will be developed to visualize performance difference.

File size: 4.3 KB
Line 
1#
2# greptest.py - Functional correctness testing for grep implementations.
3# Robert D. Cameron, Dec. 28, 2013
4# Licensed under Academic Free License 3.0
5#
6# Uses an XML test suite with the following format.
7# <greptest>
8# <datafile id="simple1">
9# A few lines of input
10# in this simple test file
11# provide fodder for some simple
12# regexp tests.
13# </datafile>
14#
15# <grepcase regexp="in" datafile="simple1" grepcount="2"/>
16# <grepcase regexp="[A-Z]" datafile="simple1" grepcount="1"/>
17#
18# </greptest>
19
20
21import sys, subprocess, os, optparse, re, codecs
22import xml.parsers.expat
23
24in_datafile = False
25
26def start_element_open_file(name, attrs):
27        global outf
28        global in_datafile
29        if name == 'datafile':
30                idFound = False
31                for a in attrs:
32                        if a == 'id':
33                                filename = attrs[a]
34                                idFound = True
35                if not idFound:
36                        print "Expecting id attribute for datafile, but none found."
37                        exit(-1)
38                outf = codecs.open(os.path.join(options.datafile_dir, filename), encoding='utf-8', mode='w')
39                in_datafile = True
40
41def char_data_write_contents(data):
42        if in_datafile:
43                outf.write(data)
44
45def end_element_close_file(name):
46        global outf
47        global in_datafile
48        if name == 'datafile':
49                outf.close()
50                in_datafile = False
51
52def make_data_files(greptest_xml):
53        p = xml.parsers.expat.ParserCreate()
54        p.StartElementHandler = start_element_open_file
55        p.CharacterDataHandler = char_data_write_contents
56        p.EndElementHandler = end_element_close_file
57        p.Parse(greptest_xml, 1)
58
59def escape_quotes(e):  return e.replace("'", "'\\''")
60
61
62failure_count = 0
63
64def start_element_do_test(name, attrs):
65        global failure_count
66        if name == 'grepcase':
67                regexp = None
68                datafile = None
69                expected_count = None
70                for a in attrs:
71                        if a == 'regexp':
72                                regexp = attrs[a]
73                        elif a == 'datafile':
74                                datafile = attrs[a]
75                        elif a == 'grepcount':
76                                expected_count = attrs[a]
77                if regexp == None or datafile == None or expected_count == None:
78                        print("Bad grepcase: missing regexp and/or datafile attributes.")
79                        return
80                #execute grep test
81                grep_cmd = "%s -c '%s' %s" % (grep_program_under_test, escape_quotes(regexp), os.path.join(options.datafile_dir, datafile))
82                if options.verbose:
83                    print "Doing: " + grep_cmd
84                try:
85                    grep_out = subprocess.check_output(grep_cmd, cwd=options.exec_dir, shell=True)
86                except subprocess.CalledProcessError, e:
87                    grep_out = e.output
88                if grep_out[-1] == '\n': grep_out = grep_out[:-1]
89                m = re.search('[0-9]+', grep_out)
90                if m == None or m.group(0) != expected_count:
91                        print("Test failure: regexp {%s} on datafile {%s} expecting {%s} got {%s}" % (regexp, datafile, expected_count, grep_out))
92                        failure_count += 1
93                else:
94                        if options.verbose:
95                                print("Test success: regexp {%s} on datafile {%s} expecting {%s} got {%s}" % (regexp, datafile, expected_count, grep_out))
96
97def run_tests(greptest_xml):
98        global failure_count
99        p = xml.parsers.expat.ParserCreate()
100        p.StartElementHandler = start_element_do_test
101        p.Parse(greptest_xml, 1)
102        if failure_count > 0: exit(1)
103
104if __name__ == '__main__':
105        QA_dir = os.path.dirname(sys.argv[0])
106        option_parser = optparse.OptionParser(usage='python %prog [options] <grep_executable>', version='1.0')
107        option_parser.add_option('-d', '--datafile_dir',
108                          dest = 'datafile_dir', type='string', default='/tmp',
109                          help = 'directory for test files.')
110        option_parser.add_option('-t', '--testcases',
111                          dest = 'testcases', type='string', default='greptest.xml',
112                          help = 'grep test case file (XML format).')
113        option_parser.add_option('-e', '--exec_dir',
114                          dest = 'exec_dir', type='string', default='.',
115                          help = 'executable directory')
116        option_parser.add_option('-v', '--verbose',
117                          dest = 'verbose', action='store_true', default=False,
118                          help = 'verbose output: show successful tests')
119        options, args = option_parser.parse_args(sys.argv[1:])
120        if len(args) != 1:
121                option_parser.print_usage()
122                sys.exit()
123        grep_program_under_test = args[0]
124        grep_test_file = open(os.path.join(QA_dir,options.testcases), 'r')
125        grep_test_spec = grep_test_file.read()
126        grep_test_file.close()
127        make_data_files(grep_test_spec)
128        run_tests(grep_test_spec)
129
130
Note: See TracBrowser for help on using the repository browser.