RFR: 7903964: Fix NPE in JTRegConfiguration.getJDKString
Jorn Vernee
jvernee at openjdk.org
Fri Mar 7 16:23:19 UTC 2025
On Wed, 5 Mar 2025 16:47:50 GMT, Oleksii Sylichenko <duke at openjdk.org> wrote:
> # This bug appears when
> - The user removes the "Build" target from "Before launch" in the Run Configuration.
> - The user unsets or does not set the Project SDK, or if it has been removed from the file system.
>
> # Steps to reproduce
>
> 1. Open a JDK project.
> 2. Open "Project Structure".
> 3. Select an SDK in the Project tab.
> 4. Navigate to "Settings → jtreg".
> 5. Set "JRE = "Default".
> 6. Run a test to automatically create a run configuration, or manually create one with "JRE = Default".
> 7. Open Project Structure again.
> 8. Set SDK = "<No SDK>".
> 9. Edit the previously created Run Configuration and remove the "Build" target from "Before launch".
> 10. Run the previously created Run Configuration.
>
> ## Expected
> - Error message appeared: "No valid JDK configured for running jtreg tests"
>
> ## Actual:
> - Nothing happened
>
> # Implemented Changes
>
> ## JTRegConfiguration.java
> - Add the `@NotNull` annotation to methods that are missing it but have it in the parent method.
> - Add javadoc to `getJDKString`.
> - Refactor `getJDKString`:
> - Fix method getJDKString, to prevent NPE when Default SDK for the project was not set
>
> ## JTRegConfigurationRunnableState.java
> - Change visibility to `public` to eliminate the warning in `JTRegConfiguration#getState`.
These changes look good, but please remove `final` from local variables here as well.
> Nothing happened
When I tested this, it was actually worse: the Run option was disabled entirely, and I had to restart the IDE to bring it back. I have created: [7903964](https://bugs.openjdk.org/browse/CODETOOLS-7903964) Please change the PR title to:
7903964: Fix NPE in JTRegConfiguration.getJDKString
-------------
PR Review: https://git.openjdk.org/jtreg/pull/251#pullrequestreview-2667615169
PR Comment: https://git.openjdk.org/jtreg/pull/251#issuecomment-2706706233
More information about the jtreg-dev
mailing list