setup-java/README.md

256 lines
8.6 KiB
Markdown
Raw Normal View History

2019-07-16 19:28:00 +02:00
# setup-java
2019-08-12 21:12:48 +02:00
<p align="left">
<a href="https://github.com/actions/setup-java"><img alt="GitHub Actions status" src="https://github.com/actions/setup-java/workflows/Main%20workflow/badge.svg"></a>
</p>
2019-07-17 16:56:53 +02:00
This action sets up a java environment for use in actions by:
- optionally downloading and caching a requested version of java by version and adding to PATH. Default downloads are populated from the [Zulu Community distribution of OpenJDK](http://static.azul.com/zulu/bin/)
2019-07-17 16:56:53 +02:00
- registering problem matchers for error output
# Usage
See [action.yml](action.yml)
## Basic
2019-07-17 16:56:53 +02:00
```yaml
2019-07-26 03:24:28 +02:00
steps:
- uses: actions/checkout@v2
2019-08-01 15:40:31 +02:00
- uses: actions/setup-java@v1
2019-07-17 16:56:53 +02:00
with:
java-version: '9.0.4' # The JDK version to make available on the path.
2019-11-22 22:26:10 +01:00
java-package: jdk # (jre, jdk, or jdk+fx) - defaults to jdk
architecture: x64 # (x64 or x86) - defaults to x64
2019-07-17 16:56:53 +02:00
- run: java -cp java HelloWorldApp
```
Examples of version specifications that the java-version parameter will accept:
- A major Java version
e.g. ```6, 7, 8, 9, 10, 11, 12, 13, ...```
2020-05-02 13:33:15 +02:00
- A semver Java version specification
e.g. ```8.0.232, 7.0.181, 11.0.4```
2020-05-02 13:33:15 +02:00
e.g. ```8.0.x, >11.0.3, >=13.0.1, <8.0.212```
2020-05-02 13:33:15 +02:00
- An early access (EA) Java version
e.g. ```14-ea, 15-ea```
2020-05-02 13:33:15 +02:00
e.g. ```14.0.0-ea, 15.0.0-ea```
2020-05-02 13:33:15 +02:00
e.g. ```14.0.0-ea.28, 15.0.0-ea.2``` (syntax for specifying an EA build number)
2020-05-02 13:33:15 +02:00
Note that, per semver rules, EA builds will be matched by explicit EA version specifications.
2020-05-02 13:33:15 +02:00
- 1.x syntax
e.g. ```1.8``` (same as ```8```)
2020-05-02 13:33:15 +02:00
e.g. ```1.8.0.212``` (same as ```8.0.212```)
2019-07-17 16:56:53 +02:00
## Local file
2019-07-17 16:56:53 +02:00
```yaml
2019-07-26 03:24:28 +02:00
steps:
- uses: actions/checkout@v2
2019-08-01 15:40:31 +02:00
- uses: actions/setup-java@v1
2019-07-17 16:56:53 +02:00
with:
2019-08-13 22:24:39 +02:00
java-version: '4.0.0'
2019-07-17 16:56:53 +02:00
architecture: x64
jdkFile: <path to jdkFile> # Optional - jdkFile to install java from. Useful for versions not found on Zulu Community CDN
2019-07-17 16:56:53 +02:00
- run: java -cp java HelloWorldApp
```
## Matrix Testing
2019-07-17 16:56:53 +02:00
```yaml
jobs:
build:
2019-08-01 17:06:31 +02:00
runs-on: ubuntu-16.04
2019-07-17 16:56:53 +02:00
strategy:
matrix:
# test against latest update of each major Java version, as well as specific updates of LTS versions:
2019-11-30 07:53:14 +01:00
java: [ 1.6, 6.0.83, 7, 7.0.181, 8, 8.0.192, 9.0.x, 10, 11.0.x, 11.0.3, 12, 13 ]
2019-07-17 16:56:53 +02:00
name: Java ${{ matrix.java }} sample
2019-07-26 03:24:28 +02:00
steps:
- uses: actions/checkout@v2
2019-07-17 16:56:53 +02:00
- name: Setup java
2019-08-01 15:40:31 +02:00
uses: actions/setup-java@v1
2019-07-17 16:56:53 +02:00
with:
2019-08-13 22:24:39 +02:00
java-version: ${{ matrix.java }}
2019-07-17 16:56:53 +02:00
- run: java -cp java HelloWorldApp
```
## Publishing using Apache Maven
### Extra setup for pom.xml:
2021-02-15 08:22:04 +01:00
The Maven GPG Plugin configuration in the pom.xml file should contain the following structure to avoid possible issues like `Inappropriate ioctl for device` or `gpg: signing failed: No such file or directory`:
2021-02-15 08:22:04 +01:00
```xml
<configuration>
<!-- Prevent gpg from using pinentry programs -->
<gpgArguments>
<arg>--pinentry-mode</arg>
<arg>loopback</arg>
</gpgArguments>
</configuration>
```
2021-02-15 08:22:04 +01:00
GPG 2.1 requires `--pinentry-mode` to be set to `loopback` in order to pick up the `gpg.passphrase` value defined in Maven `settings.xml`.
### Yaml example:
2019-11-28 23:13:35 +01:00
```yaml
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
2019-11-28 23:13:35 +01:00
- name: Set up JDK 1.8
uses: actions/setup-java@v1
2019-11-28 23:13:35 +01:00
with:
java-version: 1.8
2019-12-19 17:52:26 +01:00
2019-11-28 23:13:35 +01:00
- name: Build with Maven
run: mvn -B package --file pom.xml
2019-12-19 17:52:26 +01:00
2019-11-28 23:13:35 +01:00
- name: Publish to GitHub Packages Apache Maven
run: mvn deploy
2019-12-20 00:39:48 +01:00
env:
GITHUB_TOKEN: ${{ github.token }} # GITHUB_TOKEN is the default env for the password
2019-12-19 17:52:26 +01:00
- name: Set up Apache Maven Central
uses: actions/setup-java@v1
with: # running setup-java again overwrites the settings.xml
java-version: 1.8
2019-12-19 20:28:11 +01:00
server-id: maven # Value of the distributionManagement/repository/id field of the pom.xml
2019-12-20 00:39:48 +01:00
server-username: MAVEN_USERNAME # env variable for username in deploy
server-password: MAVEN_CENTRAL_TOKEN # env variable for token in deploy
2020-05-02 13:33:15 +02:00
gpg-private-key: ${{ secrets.MAVEN_GPG_PRIVATE_KEY }} # Value of the GPG private key to import
gpg-passphrase: MAVEN_GPG_PASSPHRASE # env variable for GPG private key passphrase
2019-12-19 17:52:26 +01:00
- name: Publish to Apache Maven Central
2020-05-02 13:33:15 +02:00
run: mvn deploy
2019-12-20 00:39:48 +01:00
env:
MAVEN_USERNAME: maven_username123
MAVEN_CENTRAL_TOKEN: ${{ secrets.MAVEN_CENTRAL_TOKEN }}
2020-05-02 13:33:15 +02:00
MAVEN_GPG_PASSPHRASE: ${{ secrets.MAVEN_GPG_PASSPHRASE }}
```
The two `settings.xml` files created from the above example look like the following.
`settings.xml` file created for the first deploy to GitHub Packages
```xml
2020-05-02 13:33:15 +02:00
<settings xmlns="http://maven.apache.org/SETTINGS/1.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 https://maven.apache.org/xsd/settings-1.0.0.xsd">
<servers>
<server>
<id>github</id>
<username>${env.GITHUB_ACTOR}</username>
<password>${env.GITHUB_TOKEN}</password>
</server>
2020-05-02 13:33:15 +02:00
<server>
<id>gpg.passphrase</id>
<passphrase>${env.GPG_PASSPHRASE}</passphrase>
</server>
</servers>
</settings>
```
`settings.xml` file created for the second deploy to Apache Maven Central
```xml
2020-05-02 13:33:15 +02:00
<settings xmlns="http://maven.apache.org/SETTINGS/1.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 https://maven.apache.org/xsd/settings-1.0.0.xsd">
<servers>
<server>
<id>maven</id>
<username>${env.MAVEN_USERNAME}</username>
<password>${env.MAVEN_CENTRAL_TOKEN}</password>
</server>
2020-05-02 13:33:15 +02:00
<server>
<id>gpg.passphrase</id>
<passphrase>${env.MAVEN_GPG_PASSPHRASE}</passphrase>
</server>
</servers>
</settings>
2019-11-28 23:13:35 +01:00
```
2019-12-06 20:50:30 +01:00
***NOTE: The `settings.xml` file is created in the Actions $HOME/.m2 directory. If you have an existing `settings.xml` file at that location, it will be overwritten. See below for using the `settings-path` to change your `settings.xml` file location.***
### GPG
2019-12-06 20:50:30 +01:00
If `gpg-private-key` input is provided, the private key will be written to a file in the runner's temp directory, the private key file will be imported into the GPG keychain, and then the file will be promptly removed before proceeding with the rest of the setup process. A cleanup step will remove the imported private key from the GPG keychain after the job completes regardless of the job status. This ensures that the private key is no longer accessible on self-hosted runners and cannot "leak" between jobs (hosted runners are always clean instances).
2021-02-16 16:12:46 +01:00
**GPG key should be exported by: `gpg --armor --export-secret-keys YOUR_ID`**
2019-11-28 23:52:51 +01:00
See the help docs on [Publishing a Package](https://help.github.com/en/github/managing-packages-with-github-packages/configuring-apache-maven-for-use-with-github-packages#publishing-a-package) for more information on the `pom.xml` file.
2019-11-28 23:13:35 +01:00
## Publishing using Gradle
2019-12-06 22:21:27 +01:00
```yaml
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
2019-12-06 22:21:27 +01:00
- name: Set up JDK 1.8
uses: actions/setup-java@v1
- name: Build with Gradle
run: gradle build
- name: Publish to GitHub Packages
run: gradle publish
env:
USERNAME: ${{ github.actor }}
PASSWORD: ${{ secrets.GITHUB_TOKEN }}
```
2020-05-02 13:33:15 +02:00
***NOTE: The `USERNAME` and `PASSWORD` need to correspond to the credentials environment variables used in the publishing section of your `build.gradle`.***
2019-12-06 22:21:27 +01:00
See the help docs on [Publishing a Package with Gradle](https://help.github.com/en/github/managing-packages-with-github-packages/configuring-gradle-for-use-with-github-packages#example-using-gradle-groovy-for-a-single-package-in-a-repository) for more information on the `build.gradle` configuration file.
## Apache Maven with a settings path
2019-12-10 22:02:21 +01:00
When using an Actions self-hosted runner with multiple shared runners the default `$HOME` directory can be shared by a number runners at the same time which could overwrite existing settings file. Setting the `settings-path` variable allows you to choose a unique location for your settings file.
```yaml
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- name: Set up JDK 1.8 for Shared Runner
uses: actions/setup-java@v1
with:
java-version: 1.8
server-id: github # Value of the distributionManagement/repository/id field of the pom.xml
settings-path: ${{ github.workspace }} # location for the settings.xml file
2019-12-19 17:52:26 +01:00
- name: Build with Maven
run: mvn -B package --file pom.xml
2019-12-19 17:52:26 +01:00
- name: Publish to GitHub Packages Apache Maven
run: mvn deploy -s $GITHUB_WORKSPACE/settings.xml
2019-12-20 00:39:48 +01:00
env:
GITHUB_TOKEN: ${{ github.token }}
```
2019-07-17 16:56:53 +02:00
# License
The scripts and documentation in this project are released under the [MIT License](LICENSE)
# Contributions
Contributions are welcome! See [Contributor's Guide](docs/contributors.md)