From: Damien Lespiau <damien.lespiau@intel.com>
To: intel-gfx@lists.freedesktop.org
Subject: [PATCH 03/23] piglit: Import igt.tests from piglit
Date: Fri, 15 Nov 2013 16:33:20 +0000 [thread overview]
Message-ID: <1384533220-20780-4-git-send-email-damien.lespiau@intel.com> (raw)
In-Reply-To: <1384533220-20780-1-git-send-email-damien.lespiau@intel.com>
Signed-off-by: Damien Lespiau <damien.lespiau@intel.com>
---
piglit/tests/igt.tests | 125 +++++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 125 insertions(+)
create mode 100644 piglit/tests/igt.tests
diff --git a/piglit/tests/igt.tests b/piglit/tests/igt.tests
new file mode 100644
index 0000000..f388492
--- /dev/null
+++ b/piglit/tests/igt.tests
@@ -0,0 +1,125 @@
+#
+# Copyright (c) 2012 Intel Corporation
+#
+# 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 testBinDir, TestProfile
+from framework.exectest import ExecTest
+
+#############################################################################
+##### 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')):
+ print "igt symlink not found!"
+ 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, arguments=[]):
+ ExecTest.__init__(self, [path.join(igtTestRoot, binary)] + arguments)
+ self.timeout = 60*20 # 20 minutes deadline by default
+
+ def interpretResult(self, out, returncode, results, dmesg):
+ if returncode == 0:
+ results['result'] = 'dmesg-warn' if dmesg != '' else 'pass'
+ elif returncode == 77:
+ results['result'] = 'skip'
+ else:
+ results['result'] = 'dmesg-fail' if dmesg != '' else 'fail'
+ return out
+ def run(self, env):
+ env.dmesg = True
+ return ExecTest.run(self, env)
+
+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[path.join('igt', test)] = IGTTest(test)
+
+def addSubTestCases(test):
+ proc = subprocess.Popen(
+ [path.join(igtTestRoot, test), '--list-subtests' ],
+ stdout=subprocess.PIPE,
+ stderr=subprocess.PIPE,
+ env=os.environ.copy(),
+ universal_newlines=True
+ )
+ out, err = proc.communicate()
+ returncode = proc.returncode
+
+ subtests = out.split("\n")
+
+ for subtest in subtests:
+ if subtest == "":
+ continue
+ profile.test_list[path.join('igt', test, subtest)] = \
+ IGTTest(test, ['--run-subtest', subtest])
+
+multiTests = listTests("list-multi-tests")
+
+for test in multiTests:
+ addSubTestCases(test)
--
1.8.3.1
next prev parent reply other threads:[~2013-11-15 16:33 UTC|newest]
Thread overview: 35+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-11-15 16:33 [igt] Making the test-suite easier to run Damien Lespiau
2013-11-15 16:33 ` [PATCH 01/23] piglit: Add a script to synchronise the piglit test runner Damien Lespiau
2013-11-15 16:33 ` [PATCH 02/23] piglit: Import piglit Damien Lespiau
2013-11-15 16:33 ` Damien Lespiau [this message]
2013-11-15 16:33 ` [PATCH 04/23] piglit: Adapt igt.tests to discover the tests directory itself Damien Lespiau
2013-11-15 16:33 ` [PATCH 05/23] piglit: Add a 'run-tests' Makefile target Damien Lespiau
2013-11-15 16:33 ` [PATCH 06/23] piglit: Add the option to inject piglit arguments Damien Lespiau
2013-11-15 16:33 ` [PATCH 07/23] piglit: Support resuming from a previous run Damien Lespiau
2013-11-15 16:33 ` [PATCH 08/23] piglit: Merge filters from previous invocations when resuming Damien Lespiau
2013-11-15 16:33 ` [PATCH 09/23] piglit: Fix resuming of previous runs Damien Lespiau
2013-11-15 16:33 ` [PATCH 10/23] piglit: Run our test suite with --no-concurrency Damien Lespiau
2013-11-15 17:08 ` Daniel Vetter
2013-11-15 17:17 ` Damien Lespiau
2013-11-15 16:33 ` [PATCH 11/23] piglit: Generate a Makefile.am from the sync script Damien Lespiau
2013-11-15 16:33 ` [PATCH 12/23] piglit: Always write the HTML test results Damien Lespiau
2013-11-15 16:33 ` [PATCH 13/23] piglit: Add a hint that there's an HTML summary Damien Lespiau
2013-11-15 16:33 ` [PATCH 14/23] framework: Humanize time values in the HTML report Damien Lespiau
2013-11-15 16:33 ` [PATCH 15/23] piglit: Support R= as RESUME= for the lazies Damien Lespiau
2013-11-15 16:33 ` [PATCH 16/23] drm_lib.sh: Tune the DRM master message a bit Damien Lespiau
2013-11-15 17:13 ` Daniel Vetter
2013-11-15 17:17 ` Damien Lespiau
2013-11-15 16:33 ` [PATCH 17/23] piglit: Make sure there's no DRM master before launching the tests Damien Lespiau
2013-11-15 16:33 ` [PATCH 18/23] piglit: Make sure we are running the tests as root Damien Lespiau
2013-11-15 16:33 ` [PATCH 19/23] piglit: Update the README file with the new way of running tests Damien Lespiau
2013-11-15 17:16 ` Daniel Vetter
2013-11-15 17:21 ` Damien Lespiau
2013-11-15 16:33 ` [PATCH 20/23] framework: Dump the result of 'uname -a' in the report Damien Lespiau
2013-11-15 16:33 ` [PATCH 21/23] lib: Introduce igt_run_quick() Damien Lespiau
2013-11-15 16:33 ` [PATCH 22/23] lib: Change SLOW_QUICK() to use igt_run_quick() Damien Lespiau
2013-11-15 16:33 ` [PATCH 23/23] pm_pc8: Use SLOW_QUICK() with the number of rounds Damien Lespiau
2013-11-15 17:20 ` [igt] Making the test-suite easier to run Damien Lespiau
2013-11-15 17:23 ` Daniel Vetter
2013-11-15 17:33 ` Mateo Lozano, Oscar
2013-11-15 17:41 ` Damien Lespiau
2013-11-15 19:27 ` Daniel Vetter
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1384533220-20780-4-git-send-email-damien.lespiau@intel.com \
--to=damien.lespiau@intel.com \
--cc=intel-gfx@lists.freedesktop.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox