RFR: 8344854: Modernize test/jdk/java/net/URLClassLoader/RemoveJar.java

Daniel Fuchs dfuchs at openjdk.org
Fri Nov 22 14:00:16 UTC 2024


On Fri, 22 Nov 2024 10:55:37 GMT, Eirik Bjørsnøs <eirbjo at openjdk.org> wrote:

> 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)

Hi Eirik, IIRC the cache is global - so I don't think running the test in the same VM will work. I mean, I don't think we will be testing the same thing.

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

PR Comment: https://git.openjdk.org/jdk/pull/22319#issuecomment-2493829085


More information about the net-dev mailing list