PlotSquared/.github/workflows/build.yml

43 lines
1.8 KiB
YAML
Raw Permalink Normal View History

2021-12-17 21:36:56 +01:00
name: build
2020-11-23 18:32:28 +01:00
2021-12-17 21:36:56 +01:00
on: [ pull_request, push ]
2020-11-23 18:32:28 +01:00
jobs:
build:
2022-01-31 21:12:00 +01:00
if: ${{ github.event_name != 'pull_request' || github.repository != github.event.pull_request.head.repo.full_name }}
2021-12-17 21:36:56 +01:00
runs-on: ubuntu-latest
2020-11-23 18:32:28 +01:00
steps:
2021-12-17 21:36:56 +01:00
- name: Checkout Repository
2022-03-08 20:50:19 +01:00
uses: actions/checkout@v3.0.0
2021-12-17 21:36:56 +01:00
- name: Validate Gradle Wrapper"
2022-03-08 20:50:19 +01:00
uses: gradle/wrapper-validation-action@v1.0.4
2021-12-17 21:36:56 +01:00
- name: Setup Java
2022-03-08 20:50:19 +01:00
uses: actions/setup-java@v3.0.0
with:
2021-12-17 21:36:56 +01:00
distribution: temurin
java-version: 17
- name: Clean Build
run: ./gradlew clean build
- name: Determine release status
if: ${{ runner.os == 'Linux' }}
run: |
if [ "$(./gradlew properties | awk '/^version:/ { print $2; }' | grep '\-SNAPSHOT')" ]; then
echo "STATUS=snapshot" >> $GITHUB_ENV
else
echo "STATUS=release" >> $GITHUB_ENV
fi
2021-12-17 21:36:56 +01:00
- name: Publish Release
if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/v6'}}
run: ./gradlew publishToSonatype closeAndReleaseSonatypeStagingRepository
env:
2021-12-17 21:36:56 +01:00
ORG_GRADLE_PROJECT_sonatypeUsername: ${{ secrets.SONATYPE_USERNAME }}
ORG_GRADLE_PROJECT_sonatypePassword: ${{ secrets.SONATYPE_PASSWORD }}
ORG_GRADLE_PROJECT_signingKey: ${{ secrets.SIGNING_KEY }}
ORG_GRADLE_PROJECT_signingPassword: ${{ secrets.SIGNING_PASSWORD }}
- name: Publish Snapshot
if: ${{ runner.os == 'Linux' && env.STATUS != 'release' && github.event_name == 'push' && github.ref == 'refs/heads/v6' }}
run: ./gradlew publishToSonatype
env:
2021-12-17 21:36:56 +01:00
ORG_GRADLE_PROJECT_sonatypeUsername: ${{ secrets.SONATYPE_USERNAME }}
ORG_GRADLE_PROJECT_sonatypePassword: ${{ secrets.SONATYPE_PASSWORD }}