RFR: 8346107: Generators: testing utility for random value generation [v14]

Andrey Turbanov aturbanov at openjdk.org
Thu Jan 9 20:31:43 UTC 2025


On Thu, 9 Jan 2025 14:02:10 GMT, Theo Weidmann <tweidmann at openjdk.org> wrote:

>> This PR is a refactoring and partial rewrite of https://github.com/openjdk/jdk/pull/22716 by @eme64. The goals remain the same:
>> 
>>> For verification testing, it is often critical to generate "interesting" values, to provoke overflows, NaN, etc. And to generate these values in the correct distribution to trigger certain optimizations.
>>> 
>>> I would like to start a collection of such generators, that can then be used in testing.
>>> 
>>> The goal is to grow this collection in the future, and add new types. For example byte, char, short, or even Float16.
>>> 
>>> This will be helpful for the Template framework [JDK-8344942](https://bugs.openjdk.org/browse/JDK-8344942), but also other tests.
>>> 
>>> Related PR, for value verification: https://github.com/openjdk/jdk/pull/22715
>> 
>> The refactoring makes use of generics, rendering the generators library more flexible by default, by allowing it work with arbitrary types (with special features for Comparable types), improving the composability of different generators and streamlining the client API for simplicity. This allows test authors to quickly compose their own distributions and generators if necessary. An overview of this functionality is provided in the `Generators` javadoc.
>
> Theo Weidmann has updated the pull request incrementally with one additional commit since the last revision:
> 
>   Update Generators.java

test/hotspot/jtreg/testlibrary_tests/generators/tests/TestGenerators.java line 420:

> 418:         // normal restrictions
> 419:         mockSource.checkEmpty().enqueueInteger(4, 6, 4);
> 420:         var g1 = mockGS.safeRestrictInt(mockGS.uniformInts(4, 5),2, 5);

Suggestion:

        var g1 = mockGS.safeRestrictInt(mockGS.uniformInts(4, 5), 2, 5);

-------------

PR Review Comment: https://git.openjdk.org/jdk/pull/22941#discussion_r1909393909


More information about the hotspot-compiler-dev mailing list