RFR: 8344854: Modernize test/jdk/java/net/URLClassLoader/RemoveJar.java
Eirik Bjørsnøs
eirbjo at openjdk.org
Fri Nov 22 11:10:49 UTC 2024
Can I get a review of this test-only cleanup/speedup PR which modernizes the test `RemoveJar.java`.
This test attempts a variety of class loading scenarios on a URLClassLoader and verifies that when the loader is closed, it has released its JAR file (such that it may be deleted on Windows).
Changes in this PR include:
* Converting the test to JUnit 5
* Making it `@Parameterized` instead of using multiple jtreg runs
* Producing the sample class file using the ClassFile API instead calling out to `javac` via ToolProvider
* Packaging the JAR using `JarOutputStream` instead of calling out to the `jar` tool.
* Adding some code and method comments to support understading of what this test does and why
A nice benefit of this change is that it speeds up the runtime from ~15 seconds to ~1 second on my laptop.
Unfortunately, this test relies on Windows to fail, that is something I plan to look into separately.
Verification: GHA tests pending. (No local Windows dev environment)
-------------
Commit messages:
- Convert RemoveJar to a parameterized JUnit 5 test
Changes: https://git.openjdk.org/jdk/pull/22319/files
Webrev: https://webrevs.openjdk.org/?repo=jdk&pr=22319&range=00
Issue: https://bugs.openjdk.org/browse/JDK-8344854
Stats: 179 lines in 1 file changed: 62 ins; 81 del; 36 mod
Patch: https://git.openjdk.org/jdk/pull/22319.diff
Fetch: git fetch https://git.openjdk.org/jdk.git pull/22319/head:pull/22319
PR: https://git.openjdk.org/jdk/pull/22319
More information about the net-dev
mailing list