CI #700
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
name: CI | |
on: | |
push: | |
branches: | |
- main | |
pull_request: | |
branches: | |
- '*' | |
schedule: | |
- cron: '0 0 * * *' | |
workflow_dispatch: | |
jobs: | |
build: | |
strategy: | |
matrix: | |
jdk: [ '17', '21', '23' ] | |
runs-on: ubuntu-latest | |
name: "Build (JDK ${{ matrix.jdk }})" | |
steps: | |
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4 | |
- uses: actions/setup-java@7a6d8a8234af8eb26422e24e3006232cccaa061b # v4 | |
id: setup-gradle-jdk | |
with: | |
distribution: liberica | |
java-version: 17 | |
- uses: actions/setup-java@7a6d8a8234af8eb26422e24e3006232cccaa061b # v4 | |
if: matrix.jdk != '17' | |
with: | |
distribution: liberica | |
java-version: ${{ matrix.jdk }} | |
- name: 'Prepare TOOLCHAIN_JDK env var' | |
if: matrix.jdk != '17' | |
shell: bash | |
run: echo "TOOLCHAIN_JDK=$JAVA_HOME" >> $GITHUB_ENV | |
- uses: gradle/actions/setup-gradle@0bdd871935719febd78681f197cd39af5b6e16a6 # v4 | |
with: | |
cache-encryption-key: ${{ secrets.GRADLE_ENCRYPTION_KEY }} | |
- shell: bash | |
env: | |
DEVELOCITY_ACCESS_KEY: ${{ secrets.DEVELOCITY_ACCESS_KEY }} | |
JAVA_HOME: ${{ steps.setup-gradle-jdk.outputs.path }} | |
run: | | |
./gradlew \ | |
-Porg.gradle.java.installations.auto-download=false \ | |
"-Dscan.value.GitHub job=${{ github.job }}" \ | |
-Dscan.tag.JDK_${{ matrix.jdk }} \ | |
-PjavaToolchainVersion=${{ matrix.jdk }} \ | |
--scan \ | |
--refresh-dependencies \ | |
javaToolchains \ | |
build | |
ea-build: | |
strategy: | |
matrix: | |
jdk: [ '23' ] | |
runs-on: ubuntu-latest | |
name: "Early Access Build (JDK ${{ matrix.jdk }})" | |
steps: | |
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4 | |
- uses: actions/setup-java@7a6d8a8234af8eb26422e24e3006232cccaa061b # v4 | |
id: setup-gradle-jdk | |
with: | |
distribution: liberica | |
java-version: 17 | |
- uses: oracle-actions/setup-java@v1 | |
with: | |
website: jdk.java.net | |
release: ${{ matrix.jdk }} | |
version: latest | |
- name: 'Prepare TOOLCHAIN_JDK env var' | |
if: matrix.jdk != '17' | |
shell: bash | |
run: echo "TOOLCHAIN_JDK=$JAVA_HOME" >> $GITHUB_ENV | |
- uses: gradle/actions/setup-gradle@0bdd871935719febd78681f197cd39af5b6e16a6 # v4 | |
with: | |
cache-encryption-key: ${{ secrets.GRADLE_ENCRYPTION_KEY }} | |
- shell: bash | |
env: | |
DEVELOCITY_ACCESS_KEY: ${{ secrets.DEVELOCITY_ACCESS_KEY }} | |
JAVA_HOME: ${{ steps.setup-gradle-jdk.outputs.path }} | |
run: | | |
./gradlew \ | |
-Porg.gradle.java.installations.auto-download=false \ | |
"-Dscan.value.GitHub job=${{ github.job }}" \ | |
-Dscan.tag.JDK_${{ matrix.jdk }} \ | |
-PjavaToolchainVersion=${{ matrix.jdk }} \ | |
--scan \ | |
--refresh-dependencies \ | |
javaToolchains \ | |
build | |
publish: | |
name: Publish Snapshots | |
needs: build | |
runs-on: ubuntu-latest | |
if: github.event_name == 'push' && github.repository == 'junit-team/testng-engine' && (startsWith(github.ref, 'refs/heads/releases/') || github.ref == 'refs/heads/main') | |
steps: | |
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4 | |
- uses: actions/setup-java@7a6d8a8234af8eb26422e24e3006232cccaa061b # v4 | |
with: | |
distribution: liberica | |
java-version: 17 | |
- uses: gradle/actions/setup-gradle@0bdd871935719febd78681f197cd39af5b6e16a6 # v4 | |
with: | |
cache-encryption-key: ${{ secrets.GRADLE_ENCRYPTION_KEY }} | |
- shell: bash | |
env: | |
DEVELOCITY_ACCESS_KEY: ${{ secrets.DEVELOCITY_ACCESS_KEY }} | |
ORG_GRADLE_PROJECT_sonatypeUsername: ${{ secrets.SONATYPE_USERNAME }} | |
ORG_GRADLE_PROJECT_sonatypePassword: ${{ secrets.SONATYPE_PASSWORD }} | |
run: | | |
./gradlew \ | |
-Porg.gradle.java.installations.auto-download=false \ | |
"-Dscan.value.GitHub job=${{ github.job }}" \ | |
-Dscan.tag.publish \ | |
--scan \ | |
javaToolchains \ | |
publish \ | |
-x check \ | |
--no-configuration-cache |