[Piglit] [PATCH] tests: Add integration with Khronos CTS OpenGL runner
Juan A. Suarez Romero
jasuarez at igalia.com
Wed May 18 13:34:07 UTC 2016
This adds support for running Khronos' deqp-based conformance suite for
OpenGL with piglit.
---
piglit.conf.example | 10 ++++++++++
tests/{cts.py => cts_gl45.py} | 43 +++++++++++++++++++++++++----------------
tests/{cts.py => cts_gles31.py} | 2 +-
3 files changed, 37 insertions(+), 18 deletions(-)
copy tests/{cts.py => cts_gl45.py} (56%)
rename tests/{cts.py => cts_gles31.py} (97%)
diff --git a/piglit.conf.example b/piglit.conf.example
index 944d5d9..3cce52a 100644
--- a/piglit.conf.example
+++ b/piglit.conf.example
@@ -95,6 +95,16 @@ testB
; overrides the value set here.
;extra_args=--deqp-visibility hidden
+[cts_gl]
+; path to the cts opengl executable
+; can be overwritten by PIGLIT_CTS_GL_BIN environment variable
+;bin=/home/knuth/cts/cts/glcts
+
+; Space-separated list of extra command line arguments for cts. The
+; option is not required. The environment variable PIGLIT_CTS_GL_EXTRA_ARGS
+; overrides the value set here.
+;extra_args=--deqp-visibility hidden
+
; Section for specific oclconform test. One of these sections is required for
; each test list in the oclconform section and must be called:
; oclconform-$testname
diff --git a/tests/cts.py b/tests/cts_gl45.py
similarity index 56%
copy from tests/cts.py
copy to tests/cts_gl45.py
index 0e64e1b..607b79b 100644
--- a/tests/cts.py
+++ b/tests/cts_gl45.py
@@ -20,25 +20,24 @@
"""Piglit integration for Khronos CTS tests.
-By default this will run GLES2, GLES3, GLES31, and GLESEXT test cases. Those
-desiring to run only a subset of them should consider using the -t or -x
-options to include or exclude tests.
+By default this will run GL30, GL31, GL32, GL33, GL40, GL41, GL42, GL43, GL44
+and GL45 test cases. Those desiring to run only a subset of them should consider
+using the -t or -x options to include or exclude tests.
For example:
-./piglit run cts -c foo -t ES3- would run only ES3 tests (note the dash to
-exclude ES31 tests)
+./piglit run cts_gl45 -c foo -t GL30- would run only GL30 tests
This integration requires some configuration in piglit.conf, or the use of
environment variables.
In piglit.conf one should set the following:
-[cts]:bin -- Path to the glcts binary
-[cts]:extra_args -- any extra arguments to be passed to cts (optional)
+[cts_gl]:bin -- Path to the glcts binary
+[cts_gl]:extra_args -- any extra arguments to be passed to cts (optional)
Alternatively (or in addition, since environment variables have precedence),
one could set:
-PIGLIT_CTS_BIN -- environment equivalent of [cts]:bin
-PIGLIT_CTS_EXTRA_ARGS -- environment equivalent of [cts]:extra_args
+PIGLIT_CTS_GL_BIN -- environment equivalent of [cts_gl]:bin
+PIGLIT_CTS_GL_EXTRA_ARGS -- environment equivalent of [cts_gl]:extra_args
"""
@@ -51,9 +50,9 @@ from framework.test import deqp
__all__ = ['profile']
-_CTS_BIN = deqp.get_option('PIGLIT_CTS_BIN', ('cts', 'bin'))
+_CTS_BIN = deqp.get_option('PIGLIT_CTS_GL_BIN', ('cts_gl', 'bin'))
-_EXTRA_ARGS = deqp.get_option('PIGLIT_CTS_EXTRA_ARGS', ('cts', 'extra_args'),
+_EXTRA_ARGS = deqp.get_option('PIGLIT_CTS_GL_EXTRA_ARGS', ('cts_gl', 'extra_args'),
default='').split()
@@ -65,18 +64,28 @@ class DEQPCTSTest(deqp.DEQPBaseTest):
return super(DEQPCTSTest, self).extra_args + \
[x for x in _EXTRA_ARGS if not x.startswith('--deqp-case')]
-
# Add all of the suites by default, users can use filters to remove them.
profile = deqp.make_profile( # pylint: disable=invalid-name
itertools.chain(
deqp.iter_deqp_test_cases(
- deqp.gen_caselist_txt(_CTS_BIN, 'ES2-CTS-cases.txt', _EXTRA_ARGS)),
+ deqp.gen_caselist_txt(_CTS_BIN, 'GL30-CTS-cases.txt', _EXTRA_ARGS)),
+ deqp.iter_deqp_test_cases(
+ deqp.gen_caselist_txt(_CTS_BIN, 'GL31-CTS-cases.txt', _EXTRA_ARGS)),
+ deqp.iter_deqp_test_cases(
+ deqp.gen_caselist_txt(_CTS_BIN, 'GL32-CTS-cases.txt', _EXTRA_ARGS)),
+ deqp.iter_deqp_test_cases(
+ deqp.gen_caselist_txt(_CTS_BIN, 'GL33-CTS-cases.txt', _EXTRA_ARGS)),
+ deqp.iter_deqp_test_cases(
+ deqp.gen_caselist_txt(_CTS_BIN, 'GL40-CTS-cases.txt', _EXTRA_ARGS)),
+ deqp.iter_deqp_test_cases(
+ deqp.gen_caselist_txt(_CTS_BIN, 'GL41-CTS-cases.txt', _EXTRA_ARGS)),
+ deqp.iter_deqp_test_cases(
+ deqp.gen_caselist_txt(_CTS_BIN, 'GL42-CTS-cases.txt', _EXTRA_ARGS)),
deqp.iter_deqp_test_cases(
- deqp.gen_caselist_txt(_CTS_BIN, 'ES3-CTS-cases.txt', _EXTRA_ARGS)),
+ deqp.gen_caselist_txt(_CTS_BIN, 'GL43-CTS-cases.txt', _EXTRA_ARGS)),
deqp.iter_deqp_test_cases(
- deqp.gen_caselist_txt(_CTS_BIN, 'ES31-CTS-cases.txt', _EXTRA_ARGS)),
+ deqp.gen_caselist_txt(_CTS_BIN, 'GL44-CTS-cases.txt', _EXTRA_ARGS)),
deqp.iter_deqp_test_cases(
- deqp.gen_caselist_txt(_CTS_BIN, 'ESEXT-CTS-cases.txt',
- _EXTRA_ARGS)),
+ deqp.gen_caselist_txt(_CTS_BIN, 'GL45-CTS-cases.txt', _EXTRA_ARGS)),
),
DEQPCTSTest)
diff --git a/tests/cts.py b/tests/cts_gles31.py
similarity index 97%
rename from tests/cts.py
rename to tests/cts_gles31.py
index 0e64e1b..ad28e58 100644
--- a/tests/cts.py
+++ b/tests/cts_gles31.py
@@ -25,7 +25,7 @@ desiring to run only a subset of them should consider using the -t or -x
options to include or exclude tests.
For example:
-./piglit run cts -c foo -t ES3- would run only ES3 tests (note the dash to
+./piglit run cts_gles31 -c foo -t ES3- would run only ES3 tests (note the dash to
exclude ES31 tests)
This integration requires some configuration in piglit.conf, or the use of
--
2.5.5
More information about the Piglit
mailing list