-
Notifications
You must be signed in to change notification settings - Fork 25k
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
[8.1] Update gradle wrapper to 7.4 (#81963) #83883
Merged
elasticsearchmachine
merged 1 commit into
elastic:8.1
from
breskeby:backport/8.1/pr-81963
Feb 14, 2022
Merged
Changes from all commits
Commits
File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
4 changes: 2 additions & 2 deletions
4
build-tools-internal/gradle/wrapper/gradle-wrapper.properties
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,6 @@ | ||
distributionBase=GRADLE_USER_HOME | ||
distributionPath=wrapper/dists | ||
distributionUrl=https\://services.gradle.org/distributions/gradle-7.3.3-all.zip | ||
distributionUrl=https\://services.gradle.org/distributions/gradle-7.4-all.zip | ||
zipStoreBase=GRADLE_USER_HOME | ||
zipStorePath=wrapper/dists | ||
distributionSha256Sum=c9490e938b221daf0094982288e4038deed954a3f12fb54cbf270ddf4e37d879 | ||
distributionSha256Sum=cd5c2958a107ee7f0722004a12d0f8559b4564c34daad7df06cffd4d12a426d0 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
32 changes: 32 additions & 0 deletions
32
...nal/src/main/java/org/elasticsearch/gradle/internal/precommit/CheckForbiddenApisTask.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
/* | ||
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one | ||
* or more contributor license agreements. Licensed under the Elastic License | ||
* 2.0 and the Server Side Public License, v 1; you may not use this file except | ||
* in compliance with, at your election, the Elastic License 2.0 or the Server | ||
* Side Public License, v 1. | ||
*/ | ||
|
||
package org.elasticsearch.gradle.internal.precommit; | ||
|
||
import de.thetaphi.forbiddenapis.gradle.CheckForbiddenApis; | ||
|
||
import org.gradle.api.file.FileTree; | ||
import org.gradle.api.tasks.IgnoreEmptyDirectories; | ||
|
||
/** | ||
* This implementation is used to fix gradle 8 compatibility of | ||
* the CheckForbiddenApis task which is built with gradle 4 support | ||
* in mind. | ||
* */ | ||
public class CheckForbiddenApisTask extends CheckForbiddenApis { | ||
|
||
/** | ||
* Add additional annotation to make this input gradle 8 compliant. | ||
* Otherwise we see a deprecation warning here starting with gradle 7.4 | ||
* */ | ||
@Override | ||
@IgnoreEmptyDirectories | ||
public FileTree getClassFiles() { | ||
return super.getClassFiles(); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1 @@ | ||
7.3.3 | ||
7.4 |
Binary file not shown.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,6 @@ | ||
distributionBase=GRADLE_USER_HOME | ||
distributionPath=wrapper/dists | ||
distributionUrl=https\://services.gradle.org/distributions/gradle-7.3.3-all.zip | ||
distributionUrl=https\://services.gradle.org/distributions/gradle-7.4-all.zip | ||
zipStoreBase=GRADLE_USER_HOME | ||
zipStorePath=wrapper/dists | ||
distributionSha256Sum=c9490e938b221daf0094982288e4038deed954a3f12fb54cbf270ddf4e37d879 | ||
distributionSha256Sum=cd5c2958a107ee7f0722004a12d0f8559b4564c34daad7df06cffd4d12a426d0 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,6 @@ | ||
distributionBase=GRADLE_USER_HOME | ||
distributionPath=wrapper/dists | ||
distributionUrl=https\://services.gradle.org/distributions/gradle-7.3.3-all.zip | ||
distributionUrl=https\://services.gradle.org/distributions/gradle-7.4-all.zip | ||
zipStoreBase=GRADLE_USER_HOME | ||
zipStorePath=wrapper/dists | ||
distributionSha256Sum=c9490e938b221daf0094982288e4038deed954a3f12fb54cbf270ddf4e37d879 | ||
distributionSha256Sum=cd5c2958a107ee7f0722004a12d0f8559b4564c34daad7df06cffd4d12a426d0 |
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
In case it could be helpful, discussions to have a fix in the plugin policeman-tools/forbidden-apis#189
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
the solutions discussed there don't sound feasible to me. Ideally there would be a forbidden api version that doesn't require compatibility with old gradle versions. Discussed that before. My ideal plan is to move away from this plugin in the long run as its a burden to maintain more and more tbh
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hi,
sorry for all this. I agree to update gradle minimum version, IF it would not be 6.8. Many projects that are using the plugin look like still on Gradle 6. Indeed the problem is also the minimum Java version while compiling, but this will change soon.
In the meantime I am about to release forbiddenapis 3.3 soon.
I know that many developers of Elasticsearch want to use forbiddenapis, but because of behavior of Gradle community and people (not willing to help) and with their shitload of changes (partly ununderstandable), this leads to issues that make plugin maintenance harder and harder. Because of this, I will in the future refuse to accept issues / PRs regarding Gradle. I mentioned this on Twitter already: https://twitter.com/thetaph1/status/1498631483887689732
@breskeby As you were working for Gradle before, maybe take your contacts and ask for including the plugin (which is only a few lines of Gradle-specific code) to the distribution and let people only configure the backend forbiddenapis JAR file (like this is done with other checkers like PMD or checkstyle which have plugin stubs in source code of Gradle and seem to be configurable to use a specific checkstyle/PMD backend). I will then only maintain the actual detection code, but I don't need to maintain the plugin in this ever-changing Gradle world which is a pain in the ass.
I may have a solution for the current problem:
plugin-init.groovy
by subclassing and use the subclassed Task class when Gradle 6.8 is detected.The first fix would be easiest and works also with custom Task setup like done in Elasticsearch (looks like you have your own plugin code to setup, because you have many more sourcesets and also use forbiddenapis to scan JAR files going back to Robert Muir's code.
If you want to have the "NO-SOURCE" message back, you can do the same like done here: subclass.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@uschindler thanks for reaching out. really appreciated.
Your first suggested solution sounds like a good compromise on keeping version compatibility and fix this problem.
I totally agree that supporting plugins over a wider range of gradle versions is not straight forward and I totally understand your pain. I did that before and it requires also proper test coverage and stepping through quite some loops. On the other hand the "aggressive" way of @gradle moving forward allows quicker innovation IMO. If having the bandwidth to stay up-to-date with gradle versions, this is a huge plus and at elastic we benefit from this a lot imo.
I don't think having the forbidden apis plugin as part of the gradle distribution is something the @gradle team would support, as the general strategy is more of making less plugins part of the distribution instead of more.
Personally, I usually just mimic the gradle version scheme for plugins, meaning that if there is a breaking change in 7.0 that affects my plugin, the major release of my plugin would support that 7.0 version and break older versions. People running with older gradle versions, usually also don't mind running on older plugin versions.
I understand that as an individual contributor doing all this in your spare time is/can be too much to ask and I understand your decision and reasoning, though I have a different perspective on certain things (the gradle community, the cache support etc.)
Declaring no further support for gradle plugin requests from your side would mean for us effectively, creating/forking our own forbidden gradle plugin, that stays up-to-date with latest gradle versions and that would have a different deprecation/support lifecycle. Ideally we make this a public stand alone plugin available via the plugin portal, but to be honest that has not the highest priority for us.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think I found an elegant solution: policeman-tools/forbidden-apis#189 (comment)
I can subclass
SourceTask
which inherits the annotation :-)There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I will of course make the plugin in a way that it works. I just won't support any crazy logic to support yet again new cache types invented all the time. Gradle is a cache-desaster (listen to complaints by Lucene people especially Robert Muir and Dawid Weiss). Gradle feels like blowing up at some point because it caches also the brain of developers! :-) Instead of caching everythingand spawning daemons all the time, there should be work on removing slow Groovy support (EA versions of Java users will thank you) and redesigning the DSL.
A standalone plugin that just depends on the forbiddenapis core JAR file would be another options, but for maintenance reasons this was abandoned, but I can reinvestiagte. It would be a simple plgin jar only containing the plugin, but no code. It would just depend on forbiddenapis main JAR file.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hi @breskeby: I found a solution for this issue, also done by a lot of other plugin authors - so I am not the first one for this specific issue. Works perfectly, no messages about deprecated features with 7.4.1: policeman-tools/forbidden-apis#193
I also fixed an issue with configuration cache (access of
Task#getProject()
during task execution caused by stupid Groovy variable/field access scopes) described in policeman-tools/forbidden-apis#179.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
New version with JDK 18 support will come out soon.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@breskeby: Version 3.3 was release a minute ago. This contains the missing annotation and on top also works with configuration cache. You may update it in Elasticsearch and remove the subclassing introduced here.