[Piglit] [PATCH 2/4] igt: new testinfrastructure to support drm/i915 kernel tests
Daniel Vetter
daniel.vetter at ffwll.ch
Tue Nov 27 11:52:46 PST 2012
Piglit as a testrunner is _so_ much better than automake's make check.
Based upon a quick patch from Kenneth Graunke.
Signed-off-by: Daniel Vetter <daniel.vetter at ffwll.ch>
---
tests/igt.tests | 99 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 99 insertions(+)
create mode 100644 tests/igt.tests
diff --git a/tests/igt.tests b/tests/igt.tests
new file mode 100644
index 0000000..863000a
--- /dev/null
+++ b/tests/igt.tests
@@ -0,0 +1,99 @@
+#
+# 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:
+#
+# This permission notice 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 AUTHOR(S) 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 os
+import re
+import sys
+import subprocess
+
+from os import path
+from framework.core import *
+from framework.exectest import *
+
+#############################################################################
+##### IGTTest: Execute an intel-gpu-tools test
+#####
+##### To use this, create an igt symlink in piglit/bin which points to the root
+##### of the intel-gpu-tools sources with the compiled tests. Piglit will
+##### automatically add all tests into the 'igt' category.
+#############################################################################
+
+if not os.path.exists(os.path.join(testBinDir, 'igt')):
+ sys.exit(0)
+
+# Chase the piglit/bin/igt symlink to find where the tests really live.
+igtTestRoot = path.join(path.realpath(path.join(testBinDir, 'igt')), 'tests')
+
+profile = TestProfile()
+
+class IGTTest(ExecTest):
+ def __init__(self, binary):
+ ExecTest.__init__(self, [path.join(igtTestRoot, binary)])
+
+ def interpretResult(self, out, returncode, results):
+ if returncode == 0:
+ results['result'] = 'pass'
+ elif returncode == 77:
+ results['result'] = 'skip'
+ else:
+ results['result'] = 'fail'
+ return out
+
+def listTests(listname):
+ oldDir = os.getcwd()
+ try:
+ os.chdir(igtTestRoot)
+ proc = subprocess.Popen(
+ ['make', listname ],
+ stdout=subprocess.PIPE,
+ stderr=subprocess.PIPE,
+ env=os.environ.copy(),
+ universal_newlines=True
+ )
+ out, err = proc.communicate()
+ returncode = proc.returncode
+ finally:
+ os.chdir(oldDir)
+
+ lines = out.split('\n')
+ found_header = False
+ progs = ""
+
+ for line in lines:
+ if found_header:
+ progs = line.split(" ")
+ break
+
+ if "TESTLIST" in line:
+ found_header = True;
+
+ return progs
+
+singleTests = listTests("list-single-tests")
+
+for test in singleTests:
+ profile.test_list['igt/' + test] = IGTTest(test)
+
+multiTests = listTests("list-multi-tests")
+
+for test in singleTests:
+ profile.test_list['igt/' + test] = IGTTest(test)
--
1.7.11.7
More information about the Piglit
mailing list