-
Notifications
You must be signed in to change notification settings - Fork 48
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Enable wrapper-validation by default in setup-gradle (#318)
- Loading branch information
Showing
20 changed files
with
559 additions
and
51 deletions.
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
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 |
---|---|---|
|
@@ -4,6 +4,9 @@ This action validates the checksums of _all_ [Gradle Wrapper](https://docs.gradl | |
|
||
The action should be run in the root of the repository, as it will recursively search for any files named `gradle-wrapper.jar`. | ||
|
||
The `setup-gradle` action will perform wrapper validation on each execution. If you are using `setup-gradle` in your | ||
workflows, it is unlikely that you will need to use this action. | ||
|
||
## The Gradle Wrapper Problem in Open Source | ||
|
||
The `gradle-wrapper.jar` is a binary blob of executable code that is checked into nearly | ||
|
@@ -90,18 +93,22 @@ We recommend the message commit contents of: | |
|
||
From there, you can easily follow the rest of the prompts to create a Pull Request against the project. | ||
|
||
## Reporting Failures | ||
## Validation Failures | ||
|
||
If this GitHub action fails because a `gradle-wrapper.jar` doesn't match one of our published SHA-256 checksums, | ||
we highly recommend that you reach out to us at [[email protected]](mailto:[email protected]). | ||
A wrapper jar can fail validation for a few reasons: | ||
1. The wrapper is from a snapshot build of Gradle (nightly or release nightly) and you have not set `allow-snapshots` | ||
or `allow-snapshot-wrappers` to `true`. | ||
2. The wrapper jar is from a version of Gradle with an unverifiable wrapper jar (see below). | ||
3. The wrapper jar was not published by Gradle, and could be compromised. | ||
|
||
**Note:** `gradle-wrapper.jar` generated by Gradle 3.3 to 4.0 are not verifiable because those files were dynamically generated by Gradle in a non-reproducible way. It's not possible to verify the `gradle-wrapper.jar` for those versions are legitimate using a hash comparison. You should try to determine if the `gradle-wrapper.jar` was generated by one of these versions before running the build. | ||
If this GitHub action fails because a `gradle-wrapper.jar` was not published by Gradle, | ||
we highly recommend that you reach out to us at [[email protected]](mailto:[email protected]). | ||
|
||
If the Gradle version in `gradle-wrapper.properties` is out of this range, you may need to regenerate the `gradle-wrapper.jar` by running `./gradlew wrapper`. If you need to use a version of Gradle between 3.3 and 4.0, you can use a newer version of Gradle to generate the `gradle-wrapper.jar`. | ||
#### Unverifiable Wrapper Jars | ||
Wrapper Jars generated by Gradle versions `3.3` to `4.0` are not verifiable because those files were dynamically generated by Gradle in a non-reproducible way. It's not possible to verify the `gradle-wrapper.jar` for those versions are legitimate using a hash comparison. If you have a validation failure, you should try to determine if the `gradle-wrapper.jar` was generated by one of these versions before running the build. | ||
|
||
If you're curious and want to explore what the differences are between the `gradle-wrapper.jar` in your possession | ||
and one of our valid release, you can compare them using this online utility: [diffoscope](https://try.diffoscope.org/). | ||
Regardless of what you find, we still kindly request that you reach out to us and let us know. | ||
- If the Gradle version in `gradle-wrapper.properties` is outside of this range, you can regenerate the `gradle-wrapper.jar` by running `./gradlew wrapper`. This will generate a new, verifiable wrapper jar. | ||
- If you need to run your build with a version of Gradle between 3.3 and 4.0, you can use a newer version of Gradle to generate the `gradle-wrapper.jar`. | ||
|
||
## Resources | ||
|
||
|
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
Oops, something went wrong.