[Piglit] [PATCH 3/4] apitrace: Add a script for capturing and comparing trace images.

Eric Anholt eric at anholt.net
Tue Aug 23 01:41:35 UTC 2016


---
 tests/apitrace/test-trace.py | 162 +++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 162 insertions(+)
 create mode 100755 tests/apitrace/test-trace.py

diff --git a/tests/apitrace/test-trace.py b/tests/apitrace/test-trace.py
new file mode 100755
index 000000000000..dff64b31bc9d
--- /dev/null
+++ b/tests/apitrace/test-trace.py
@@ -0,0 +1,162 @@
+#!/usr/bin/env python
+
+# Copyright (c) 2016 Broadcom
+#
+# Permission is hereby granted, free of charge, to any person obtaining a
+# copy of this software and associated documentation files (the "Software"),
+# to deal in the Software without restriction, including without limitation
+# the rights to use, copy, modify, merge, publish, distribute, sublicense,
+# and/or sell copies of the Software, and to permit persons to whom the
+# Software is furnished to do so, subject to the following conditions:
+#
+# The above copyright notice and this permission notice (including the next
+# paragraph) shall be included in all copies or substantial portions of the
+# Software.
+#
+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
+# THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
+# IN THE SOFTWARE.
+
+import argparse
+import re
+import sys, os
+import subprocess
+
+def usage():
+    USAGE = """\
+Usage: %(progName)s filename.trace specific,then,general,categories
+"""
+    print(USAGE % {'progName': sys.argv[0]})
+    sys.exit(1)
+
+class TraceResult:
+    def __init__(self):
+        self.out = ""
+        self.err = ""
+
+def piglit_report_result(result):
+    str = 'PIGLIT: {{"result": "{}" }}\n'.format(result)
+    if result == 'warn' or result == 'fail':
+        sys.stderr.write(str)
+        exit(1)
+    else:
+        sys.stdout.write(str)
+        exit(0)
+
+def piglit_merge_result(result, sub_result):
+    if result == 'skip':
+        return sub_result
+    elif sub_result == 'pass':
+        return result
+    elif sub_result == 'fail':
+        return sub_result
+    else:
+        print('unknown sub result {}'.format(sub_result))
+        piglit_report_result('fail')
+
+def run_and_collect_output(filename):
+    # Save off the path to the trace, minus '.trace'
+    trace_prefix = os.path.splitext(filename)[0]
+
+    # Place our generated .pngs in the directory of the trace, named
+    # "tracename.out.drawcall.png".
+    trace_png_prefix='{}.out.'.format(trace_prefix)
+
+    command = [
+        'apitrace',
+        'replay',
+        '-b', # No performance debugging or glGetError()s, please.
+        '-v', # Get the "Wrote ..." lines.
+        '-s', # Write pngs with the following prefix.
+        trace_png_prefix,
+        filename
+    ]
+
+    try:
+        p = subprocess.Popen(
+            command,
+            stdout=subprocess.PIPE,
+            stderr=subprocess.PIPE)
+        (stdout, stderr) = p.communicate()
+        apitrace_output = (stdout + stderr).decode("utf-8")
+    except KeyboardInterrupt:
+        exit(1)
+    except:
+        piglit_report_result('fail')
+
+    return apitrace_output
+
+def compare_images(out, expected):
+    """Uses apitrace diff-images to compare two images, returning a
+
+    piglit status string.
+    """
+    command = [
+        'apitrace',
+        'diff-images',
+        '-a', # alpha channel counts
+        out,
+        expected,
+    ]
+
+    retcode = subprocess.call(command)
+    if retcode == 0:
+        return 'pass'
+    elif retcode == 1:
+        return 'fail'
+    else:
+        print('unknown apitrace diff-images return code {}'.format(retcode))
+        piglit_report_result('fail')
+
+    return result
+
+def run_trace(filename, driver_categories):
+    basename = os.path.basename(filename)
+
+    apitrace_output = run_and_collect_output(filename)
+
+    tested_imagemagick = False
+    result = 'skip'
+    for line in apitrace_output.splitlines():
+        m = re.match('Wrote (.*)\.out\.(.*).png', line)
+        if m is None:
+            continue
+
+        prefix = m.group(1)
+        drawcall = m.group(2)
+        out_file = '{}.out.{}.png'.format(prefix, drawcall)
+
+        # Go through the list of categories our driver
+        for category in driver_categories:
+            expected_file = '{}.expected.{}.{}.png'.format(prefix,
+                                                            category,
+                                                            drawcall)
+            print('looking for {}'.format(expected_file))
+            if not os.path.isfile(expected_file):
+                continue
+
+            sub_result = compare_images(out_file, expected_file)
+
+            result = piglit_merge_result(result, sub_result)
+            break
+
+    piglit_report_result(result)
+
+def main():
+    parser = argparse.ArgumentParser()
+    parser.add_argument("filename",
+                        metavar="<file.trace>",
+                        help="Path to apitrace file")
+    parser.add_argument("driver_categories",
+                        metavar="<driver,categories>",
+                        help="Driver categories to look for expected images in, in least-specific to most-specific order, separated by commas")
+    args = parser.parse_args()
+
+    run_trace(args.filename, args.driver_categories.split(','))
+
+if __name__ == "__main__":
+	main()
-- 
2.9.3



More information about the Piglit mailing list