X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;f=driver.py;h=f909a45c65a515da0b2a15ac8fa3cc5f9a88a2f4;hb=3386fbd0792fa8810fbef8aa1903bdc089d0d4ef;hp=e219e611c9288022c2bd947a1648177e7fca89be;hpb=7949d2e03c697fc73f3d2ec882c08b487d1422bd;p=apitrace-tests diff --git a/driver.py b/driver.py index e219e61..f909a45 100755 --- a/driver.py +++ b/driver.py @@ -65,8 +65,8 @@ def _get_build_program(program): class TestCase: + api = 'gl' max_frames = None - trace_file = None def __init__(self, name, args, cwd=None, build=None, results = '.'): @@ -87,6 +87,13 @@ class TestCase: if p.returncode: self.skip('application returned code %i' % p.returncode) + api_map = { + 'gl': 'gl', + 'egl_gl': 'egl', + 'egl_gles1': 'egl', + 'egl_gles2': 'egl', + } + def trace(self): if self.trace_file is None: self.trace_file = os.path.abspath(os.path.join(self.results, self.name + '.trace')) @@ -111,7 +118,8 @@ class TestCase: apitrace = _get_build_program('apitrace') cmd = [ apitrace, 'trace', - '-o', self.trace_file, + '--api', self.api_map[self.api], + '--output', self.trace_file, '--' ] + cmd if self.max_frames is not None: @@ -138,13 +146,14 @@ class TestCase: flushes = 0 ref_line = '' + src_lines = [] if self.ref_dump is not None: ref = open(self.ref_dump, 'rt') ref_line = ref.readline().rstrip() for line in p.stdout: line = line.rstrip() + print line mo = self.call_re.match(line) - assert mo if mo: call_no = int(mo.group(1)) function_name = mo.group(2) @@ -153,15 +162,24 @@ class TestCase: if function_name in ('glFlush', 'glFinish'): flushes += 1 src_line = line[mo.start(2):] - if ref_line: - if src_line == ref_line: - sys.stdout.write(src_line + '\n') - ref_line = ref.readline().rstrip() + else: + src_line = line + if ref_line: + if src_line == ref_line: + sys.stdout.write(src_line + '\n') + ref_line = ref.readline().rstrip() + src_lines = [] + else: + src_lines.append(src_line) + p.wait() if p.returncode != 0: self.fail('`apitrace dump` returned code %i' % p.returncode) if ref_line: - self.fail('missing call %s' % ref_line) + if src_lines: + self.fail('missing call `%s` (found `%s`)' % (ref_line, src_lines[0])) + else: + self.fail('missing call %s' % ref_line) def run(self): self.standalone() @@ -248,6 +266,10 @@ def main(): optparser = optparse.OptionParser( usage='\n\t%prog [options] -- program [args] ...', version='%%prog') + optparser.add_option( + '-a', '--api', metavar='API', + type='string', dest='api', default='gl', + help='api to trace') optparser.add_option( '-B', '--build', metavar='PATH', type='string', dest='build', default='..', @@ -276,6 +298,7 @@ def main(): build = options.build, results = options.results, ) + test.api = options.api test.ref_dump = options.ref_dump test.run()