X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;f=driver.py;h=8c7d1268bb61e9e2fc2a1b5fe82d14f1f5209979;hb=956433aa964937908b070c5f0ce9d8465e3751da;hp=48b04ece6a355f021ee27592b660aecd687b44d6;hpb=6bd03f06bc7875962e85cc643b54b7ed093b9900;p=apitrace-tests diff --git a/driver.py b/driver.py index 48b04ec..8c7d126 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 = '.'): @@ -97,6 +97,7 @@ class TestCase: if not os.path.exists(trace_dir): os.makedirs(trace_dir) + cmd = self.args env = os.environ.copy() system = platform.system() @@ -105,19 +106,20 @@ class TestCase: wrapper = _get_build_path('wrappers/opengl32.dll') local_wrapper = os.path.join(os.path.dirname(self.args[0]), os.path.basename(wrapper)) shutil.copy(wrapper, local_wrapper) - elif system == 'Darwin': - wrapper = _get_build_path('wrappers/OpenGL') - env['DYLD_LIBRARY_PATH'] = os.path.dirname(wrapper) + env['TRACE_FILE'] = self.trace_file else: - wrapper = _get_build_path('glxtrace.so') - env['LD_PRELOAD'] = wrapper - - env['TRACE_FILE'] = self.trace_file + apitrace = _get_build_program('apitrace') + cmd = [ + apitrace, 'trace', + '--api', self.api, + '--output', self.trace_file, + '--' + ] + cmd if self.max_frames is not None: env['TRACE_FRAMES'] = str(self.max_frames) try: - p = popen(self.args, env=env, cwd=self.cwd) + p = popen(cmd, env=env, cwd=self.cwd) p.wait() finally: if local_wrapper is not None: @@ -130,13 +132,14 @@ class TestCase: def dump(self): - cmd = [_get_build_program('tracedump'), '--color=never', self.trace_file] + cmd = [_get_build_program('apitrace'), 'dump', '--color=never', self.trace_file] p = popen(cmd, stdout=subprocess.PIPE) swapbuffers = 0 flushes = 0 ref_line = '' + src_lines = [] if self.ref_dump is not None: ref = open(self.ref_dump, 'rt') ref_line = ref.readline().rstrip() @@ -156,11 +159,18 @@ class TestCase: 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('tracedump returned code %i' % p.returncode) + 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() @@ -247,6 +257,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='..', @@ -275,6 +289,7 @@ def main(): build = options.build, results = options.results, ) + test.api = options.api test.ref_dump = options.ref_dump test.run()