-
Notifications
You must be signed in to change notification settings - Fork 99
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[FEATURE] Support running Gradle with JDK versions above Gradle's official support range #660
Comments
Alternatively I'd love to disable this init behavior in this case, unless it's crucial to the execution of the action |
@JLLeitschuh If the init-script was written in Kotlin, how would you support older versions of Gradle? The way it works now, the init-script is written without any knowledge of which Gradle versions will be executed in a workflow.
In this case you'd lose the build results in the Job Summary, as well as the upcoming dependency-submission support (which will also leverage an init-script). Perhaps you could combine these 2 options, by allowing a workflow to explicitly opt-in to Kotlin-based init-scripts. We'd need to maintain 2 different init-script versions, and possibly we'd want to migrate more of the build-results-capture functionality to Java to enable reuse. Would you be interested in contributing a PR for this feature? |
Hrm... I guess the tradeoff here is forwards compatibility vs backwards compatibility. Maybe this should be considered a bug in Gradle that it doesn't have implicit forward compatibility |
@bigdaz could we do loose version checking of the Gradle properties file. If the version is in a range that supports kotlin files, drop a kotlin script, otherwise, drop a Groovy file? If we can't determine the version, always fallback to a Groovy file. Do you think this would work? |
It might work, but it could cause for projects that do CI runs with different versions of Gradle. |
The |
Hear me out, this is currently already supported by Gradle, but this doesn't work when applying this action.
If you have a Gradle build that is entirely written in Kotlin, you can run that build on a JVM that is above the supported version range of Gradle.
For example, I currently have a Gradle build using Gradle
7.1.1
and7.3.3
running on JDK 20, a version that Gradle 8.0 still doesn't officially support, but it's doing so without failure.However, as soon as you apply this action, the JDK support is restricted to the range of versions that Gradle officially supports. That's because Gradle compiles groovy script files with the current JDK, which generates a class file with the JDK version header. Then when Gradle attempts to execute that file, it blows up, stating that class files of that version aren't supported.
The best way that this could be fixed by this plugin would be to either:
That way, if you apply this plugin, you can still take advantage of the rest of the features, like the great caching support, but you can still run on much higher versions of the JDK than the version of Gradle being used supports.
When is this needed: primarily when developing Gradle plugins.
Show me an example
Gradle build runs fine on JDK 20, even though Gradle's official documentation states that no version of Gradle supports it.
Example of a build where applying this action breaks the build due to the class file incompatibility:
The text was updated successfully, but these errors were encountered: