JDK 9 RFR of JDK-8078334: Mark regression tests using randomness

Joseph D. Darcy joe.darcy at oracle.com
Wed Apr 22 02:13:16 UTC 2015


Hello,

As the next step of implementing "Proposed new policies for JDK 9 
regression tests: tiered testing, intermittent failures, and randomness" 
[1], please review this changeset which adds a "randomness" jtreg 
keyword and tags 240 regression tests in the jdk repository with the 
keyword:

     JDK-8078334: Mark regression tests using randomness
     http://cr.openjdk.java.net/~darcy/8078334.0/

The update to test/TEST.ROOT is

-# The list of keywords supported in the entire test suite
-keys=2d dnd i18n intermittent
+# The list of keywords supported in the entire test suite.  The
+# "intermittent" keyword marks tests known to fail intermittently.
+# The "randomness" keyword marks tests using randomness with test
+# cases differing from run to run. (A test using a fixed random seed
+# would not count as "randomness" by this definition.) Extra care
+# should be taken to handle test failures of intermittent or
+# randomness tests.
+
+keys=2d dnd i18n intermittent randomness

To find the affected files for this fix, I grepped over the regression 
tests looking for "random" and verified if a random number generated was 
used in a way where its values would differ from run to run. In 
particular, as noted above, a java.util.Random random number generator 
with a fixed seed did *not* qualify a test for the "randomness" keyword.

The usual update to the files in this changeset is just

+ * @key randomness

The updated tests are mostly in the core libs and security libs areas 
with a few serviceability tests too. The list in this bug is not quite 
exhaustive; I did not include rmi tests or client libraries tests.

I verified that running

     jtreg ... -l -k:randomness .

returns the expected number of tests and that the tests continue to pass 
(or be ignored) when run.

One goal of marking the tests using randomness is to help root out some 
remaining intermittent test failures. If one of the randomness tests is 
observed to fail intermittently, if it has not already been updated to 
print out the random seed and be able to accept a particular seed when 
run, the test should be so modified so that future failures can log the 
seed value in hopes of reproducing the failure.

Brian Burkhalter has proactively made these sorts of changes to the 
java.math tests earlier in JDK 9. [2] Since most of the randomness tests 
don't have a history of instability (and due to the unexpected large 
number of them!), I don't think it is necessary to proactively update 
all the other tests without evidence of a history of failure. However, 
when an otherwise unexplained failure is seen, I recommend applying the 
sort of updates Brian has done in java.math to the failing test(s).

Thanks,

-Joe

[1] http://mail.openjdk.java.net/pipermail/jdk9-dev/2015-March/001991.html

[2] JDK-8074460, Always print seeds used in [Splittable]Random instances 
in java.math tests,
https://bugs.openjdk.java.net/browse/JDK-8074460



More information about the security-dev mailing list