[Piglit] [PATCH] framework: Handle tests with subtests crashing in totals
Dylan Baker
dylan at pnwbakers.com
Fri Jan 19 23:26:57 UTC 2018
I mean to CC Fabien as well...
Quoting Dylan Baker (2018-01-19 14:04:13)
> Currently piglit doesn't account for a test with subtests crashing when
> it calculates the total number of tests of each status. The result is
> that if a test with subtests runs no tests before crashing it is handled
> correctly (since it goes down the non-subtest path), but if one or more
> subtests are run, and those tests return a better result than crash,
> then the test will be marked as that status instead.
>
> The real problem is that the python framework has no idea how many
> subtests that a test binary is going to run, so if the test crashes it
> has no idea if some subtests weren't run. To paper over that if the
> result of a test is not the same as the worst result of it's subtests
> we'll treat the test as a single test rather than a group, this results
> in the summaries generating the expected results.
>
> A better fix would be to have tests with subtests inform the framework
> (preferably via JSON) that all of the subtests that it will run before
> it starts running, so that the python framework can pre-populate the
> subtests and generate the right result.
>
> This solution is a better in the short term because it makes the results
> consistent, if a test crashes or not it will produce the same results.
>
> Signed-off-by: Dylan Baker <dylan.c.baker at intel.com>
> ---
> framework/results.py | 7 ++++++-
> 1 file changed, 6 insertions(+), 1 deletion(-)
>
> diff --git a/framework/results.py b/framework/results.py
> index 99dd3735b..4c7266208 100644
> --- a/framework/results.py
> +++ b/framework/results.py
> @@ -329,7 +329,12 @@ class TestrunResult(object):
> for name, result in six.iteritems(self.tests):
> # If there are subtests treat the test as if it is a group instead
> # of a test.
> - if result.subtests:
> + # FIXME: If there overall test crashed, then don't treat it as a
> + # group, ignore all of the subtests and report that the test was
> + # crash. This is just papering over the fact that the binaries
> + # don't inform the python layer how many subtests (and the names)
> + # of the subtests it wants to run.
> + if result.subtests and result.result == max(six.itervalues(result.subtests)):
> for res in six.itervalues(result.subtests):
> res = str(res)
> temp = name
> --
> 2.15.1
>
> _______________________________________________
> Piglit mailing list
> Piglit at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/piglit
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 488 bytes
Desc: signature
URL: <https://lists.freedesktop.org/archives/piglit/attachments/20180119/3df06e96/attachment-0001.sig>
More information about the Piglit
mailing list