[jdk21u-dev] RFR: 8375080: The tools/jpackage/windows/Win8365790Test.java may fail with ClassNotFoundException: jtreg.SkippedException

Alexey Semenyuk asemenyuk at openjdk.org
Wed Feb 11 13:33:56 UTC 2026


On Tue, 10 Feb 2026 18:46:45 GMT, Min Choi <duke at openjdk.org> wrote:

> `Win8365790Test` calls `TKit.throwSkippedException()` when the test environment doesn't support Ctrl+C signal delivery.
> 
> In JDK 17/21, `TKit.throwSkippedException()` uses reflection (`Class.forName("jtreg.SkippedException")`) to load the exception class, which requires `jtreg.SkippedException` to be on the classpath.
> 
> public static RuntimeException throwSkippedException(String reason) {
>     trace("Skip the test: " + reason);
>     RuntimeException ex = ThrowingSupplier.toSupplier(
>             () -> (RuntimeException) Class.forName("jtreg.SkippedException").getConstructor(
>                     String.class).newInstance(reason)).get();
>     currentTest.notifySkipped(ex);
>     throw ex;
> }
> 
> 
> The test was missing the jtreg directives to build this class:
> 
> @library /test/lib
> @build jtreg.SkippedException
> 
> 
> This pattern is already used by other jpackage tests that call `throwSkippedException()` (e.g., `SigningAppImageTest.java`).
> 
> Note: JDK 25+ has this fixed differently via [JDK-8352419](https://bugs.openjdk.org/browse/JDK-8352419) which [hardcodes](https://github.com/openjdk/jdk/commit/70e325004536eb9b79f4943f27eed4ac6cec8bd5#diff-409e0d5eb5d024e7613e041c416fe862752cce72f19c80bb585511239fab9399R1144-R1170) `SkippedException` directly in `TKit.java`.

Isn't it the same issue as the one discussed in https://github.com/openjdk/jdk/pull/29416?

The better fix would be to backport the part of the [JDK-8352419](https://bugs.openjdk.org/browse/JDK-8352419) fix which hardcodes SkippedExeption class into test/jdk/tools/jpackage/helpers/jdk/jpackage/test/TKit.java‎. This way, it will be consistent across all releases, and other jpackage tests will benefit from the properly working "skip the test" mechanism.

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

PR Comment: https://git.openjdk.org/jdk21u-dev/pull/2606#issuecomment-3884463216


More information about the jdk-updates-dev mailing list