2019-07-16 13:28:00 -04:00
# setup-java
2019-08-12 15:12:48 -04: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 10:56:53 -04:00
This action sets up a java environment for use in actions by:
2019-11-03 00:39:35 -04:00
- 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 10:56:53 -04:00
- registering problem matchers for error output
# Usage
See [action.yml ](action.yml )
Basic:
```yaml
2019-07-25 21:24:28 -04:00
steps:
2019-11-08 11:40:52 -05:00
- uses: actions/checkout@v1
2019-08-01 09:40:31 -04:00
- uses: actions/setup-java@v1
2019-07-17 10:56:53 -04:00
with:
2019-11-22 16:26:10 -05:00
java-version: '9.0.4' # The JDK version to make available on the path. Takes a whole or semver JDK version, or 1.x syntax (e.g. 1.8 => Jdk 8.x). To specify a specific version for JDK 8 or older use the following pattern (8.0.x)
java-package: jdk # (jre, jdk, or jdk+fx) - defaults to jdk
architecture: x64 # (x64 or x86) - defaults to x64
2019-07-17 10:56:53 -04:00
- run: java -cp java HelloWorldApp
```
From local file:
```yaml
2019-07-25 21:24:28 -04:00
steps:
2019-11-08 11:40:52 -05:00
- uses: actions/checkout@v1
2019-08-01 09:40:31 -04:00
- uses: actions/setup-java@v1
2019-07-17 10:56:53 -04:00
with:
2019-08-13 16:24:39 -04:00
java-version: '4.0.0'
2019-07-17 10:56:53 -04:00
architecture: x64
2019-11-03 00:39:35 -04:00
jdkFile: < path to jdkFile > # Optional - jdkFile to install java from. Useful for versions not found on Zulu Community CDN
2019-07-17 10:56:53 -04:00
- run: java -cp java HelloWorldApp
```
Matrix Testing:
```yaml
jobs:
build:
2019-08-01 11:06:31 -04:00
runs-on: ubuntu-16.04
2019-07-17 10:56:53 -04:00
strategy:
matrix:
2019-11-03 00:39:35 -04:00
# test against latest update of each major Java version, as well as specific updates of LTS versions:
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 10:56:53 -04:00
name: Java ${{ matrix.java }} sample
2019-07-25 21:24:28 -04:00
steps:
2019-07-23 15:46:09 -04:00
- uses: actions/checkout@master
2019-07-17 10:56:53 -04:00
- name: Setup java
2019-08-01 09:40:31 -04:00
uses: actions/setup-java@v1
2019-07-17 10:56:53 -04:00
with:
2019-08-13 16:24:39 -04:00
java-version: ${{ matrix.java }}
2019-07-17 10:56:53 -04:00
- run: java -cp java HelloWorldApp
```
2019-11-28 17:13:35 -05:00
Publising to an Apache Maven Repository:
```yaml
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v1
- name: Set up JDK 1.8
2019-12-04 23:22:47 -05:00
uses: actions/setup-java@v1
2019-11-28 17:13:35 -05:00
with:
java-version: 1.8
server-id: github # Value of the distributionManagement/repository/id field of the pom.xml
username: ${{ github.actor }} # username for server authentication
password: ${{ github.token }} # password or token for authentication
- name: Build with Maven
run: mvn -B package --file pom.xml
- name: Publish to GitHub Packages Apache Maven
run: mvn deploy
2019-11-29 12:26:29 -05:00
- name: Set up Apache Maven Central
2019-12-04 23:22:47 -05:00
uses: actions/setup-java@v1
2019-11-29 12:26:29 -05:00
with: # running setup-java again overwrites the settings.xml
java-version: 1.8
server-id: maven
username: maven_username
password: ${{ secrets.MAVEN_CENTRAL_TOKEN }} # password from secrets store
- name: Publish to Apache Maven Central
run: mvn deploy
2019-11-28 17:13:35 -05:00
```
2019-11-28 17:52:51 -05: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 17:13:35 -05:00
2019-07-17 10:56:53 -04: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 )