[Piglit] [PATCH] junit.py: Escape `api`/`search` in test's classname too.
Dylan Baker
baker.dylan.c at gmail.com
Tue Apr 28 10:53:56 PDT 2015
I have a few style comments, but otherwise this looks good, with the
below addressed:
Reviewed-by: Dylan Baker <baker.dylan.c at gmail.com>
On Mon, Apr 27, 2015 at 03:44:19PM +0100, Jose Fonseca wrote:
> If `api` appears in the middle of the test classname, like it happens
> with all `spec/glsl-1.20/api/getactiveattrib *` tests, then Jenkins will
> intercept it making it impossible to see individual tests results.
> Therefore, just like the testname, it must be escaped.
>
> This escaping will affect the expected failure/crash test matching. I
> can't think of another solution though...
> ---
> framework/backends/junit.py | 16 +++++++++++++---
> 1 file changed, 13 insertions(+), 3 deletions(-)
>
> diff --git a/framework/backends/junit.py b/framework/backends/junit.py
> index 3602f9e..c6219e2 100644
> --- a/framework/backends/junit.py
> +++ b/framework/backends/junit.py
> @@ -40,6 +40,15 @@ __all__ = [
> ]
>
>
> +junitSpecialNames = ('api', 'search')
If this is a constant it should be all caps, per PEP8; also, please add
an additional newline here. Since this is an internal constant you might
consider calling it '_JUNIT_SPECIAL_NAMES', which will hide it from
export.
> +
> +def junitEscape(name):
Per PEP8, function names should be all lower case with underscores to
separate words. Could we change this to 'junit_escape(name)'?
> + name = name.replace('.', '_')
> + if name in junitSpecialNames:
> + name += '_'
> + return name
> +
> +
> class JUnitBackend(FileBackend):
> """ Backend that produces ANT JUnit XML
>
> @@ -161,8 +170,9 @@ class JUnitBackend(FileBackend):
> # classname), and replace piglits '/' separated groups with '.', after
> # replacing any '.' with '_' (so we don't get false groups).
> classname, testname = grouptools.splitname(name)
> - classname = classname.replace('.', '_')
> - classname = classname.replace(grouptools.SEPARATOR, '.')
> + classname = classname.split(grouptools.SEPARATOR)
> + classname = map(junitEscape, classname)
map is discouraged in python, '[junit_escape(e) for e in classname]', is
the more standard way.
> + classname = '.'.join(classname)
>
> # Add the test to the piglit group rather than directly to the root
> # group, this allows piglit junit to be used in conjunction with other
> @@ -177,7 +187,7 @@ class JUnitBackend(FileBackend):
> # The testname variable is used in the calculate_result
> # closure, and must not have the suffix appended.
> full_test_name = testname + self._test_suffix
> - if full_test_name in ('api', 'search'):
> + if full_test_name in junitSpecialNames:
> testname += '_'
> full_test_name = testname + self._test_suffix
>
> --
> 2.1.0
>
> _______________________________________________
> Piglit mailing list
> Piglit at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/piglit
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 473 bytes
Desc: Digital signature
URL: <http://lists.freedesktop.org/archives/piglit/attachments/20150428/6de55b8f/attachment.sig>
More information about the Piglit
mailing list