Unciv/.github/workflows/buildAndDeploy.yml
2023-03-08 10:46:15 +02:00

371 lines
13 KiB
YAML

# This is a basic workflow to help you get started with Actions
name: Build and deploy
# Controls when the action will run.
on:
# Triggers the workflow on push or pull request events but only for the master branch
push:
tags:
- '*' # This doesn't mean that it HAS to have a tag, only that the workflow triggers when we push a tag
branches: [ master ]
pull_request:
branches: [ master ]
# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
jobs:
Build:
# On push events only, if it's a "Update X" commit, it's probably something done through the UI -
# so an .md or yaml change, and not something we need to rebuild over
# We can't simply put !startsWith - see https://github.community/t/expression-syntax-for-not-startswith/17040
if: github.event_name != 'push' || startsWith(github.event.commits[0].message, 'Update ') != true
runs-on: ubuntu-latest
outputs:
version_tag: ${{ steps.tag.outputs.tag }}
release_body: ${{steps.read_release.outputs.release_body}}
steps:
- uses: actions/checkout@v3
- uses: actions/setup-java@v3
with:
distribution: 'temurin'
java-version: '11'
- name: Setup Gradle
uses: gradle/gradle-build-action@v2.3.3
- name: Compile kotlin and build classes
run: ./gradlew classes
- name: Run code checks
run: ./gradlew check
- name: Run unit tests
run: ./gradlew --no-build-cache cleanTest test tests:test
# RELEASE
- name: Get release tag # We can then get the tag using ${{steps.tag.outputs.tag}} as below
if: github.event_name == 'push' && contains(github.ref, 'refs/tags/')
id: tag
uses: dawidd6/action-get-tag@v1
- name: Read release.md and use it as a body of new release. This will fail for patch releases, since they have no readme.
continue-on-error: true
if: github.event_name == 'push' && contains(github.ref, 'refs/tags/')
id: read_release
shell: bash
run: |
## To test this in Windows PS: cat .\changelog.md | wsl grep -Pzo --color '\\#{2}.3.15.7[^\\#]*?\\#{2}' | wsl head -n -2
r=$(grep -Pzo '\#{2}.${{steps.tag.outputs.tag}}[^\#]*\#' changelog.md) # grep to get only our release
r=$(echo "$r" | head -n -2 | tail -n +3)
## See https://trstringer.com/github-actions-multiline-strings/
echo "--- Set variable manually in github env ---"
echo "release_body<<EOF" >> $GITHUB_OUTPUT
echo "$r" >> $GITHUB_OUTPUT
echo "EOF" >> $GITHUB_OUTPUT
## DESKTOP
- name: Build UncivServer.jar
continue-on-error: true
if: github.event_name == 'push' && contains(github.ref, 'refs/tags/')
run: |
./gradlew desktop:dist
./gradlew desktop:zipLinuxFilesForJar
- name: Upload JAR
uses: actions/upload-artifact@v3
with:
name: UncivJar
path: |
desktop/build/libs/Unciv.jar
deploy/linuxFilesForJar.zip
## Server
- name: Build UncivServer.jar
continue-on-error: true
if: github.event_name == 'push' && contains(github.ref, 'refs/tags/')
run: |
./gradlew server:dist
- name: Upload Server
uses: actions/upload-artifact@v3
with:
name: UncivServer
path: server/build/libs/UncivServer.jar
## ANDROID
android-build:
if: github.event_name == 'push' && contains(github.ref, 'refs/tags/')
runs-on: ubuntu-latest
needs: Build
steps:
- uses: actions/checkout@v3
- uses: actions/setup-java@v3
with:
distribution: 'temurin'
java-version: '11'
- name: Setup Gradle
uses: gradle/gradle-build-action@v2.3.3
- name: Prepare .aab (for Google Play) and .apk (for Github) files
continue-on-error: true
if: github.event_name == 'push' && contains(github.ref, 'refs/tags/')
shell: bash
run: |
mkdir whatsNewDirectory
echo "${{needs.Build.outputs.release_body}}" > whatsNewDirectory/whatsnew-en-US
./gradlew :android:bundleRelease
./gradlew :android:assembleRelease
- name: Sign AAB for Google Play upload
uses: r0adkll/sign-android-release@v1
if: github.event_name == 'push' && contains(github.ref, 'refs/tags/')
with:
releaseDirectory: android/build/outputs/bundle/release
signingKeyBase64: ${{ secrets.BUNDLE_SIGNING_KEY_BASE64 }}
alias: ${{ secrets.BUNDLE_SIGNING_KEY_ALIAS }}
keyStorePassword: ${{ secrets.BUNDLE_SIGNING_KEYSTORE_PASSWORD }}
keyPassword: ${{ secrets.BUNDLE_SIGNING_KEY_PASSWORD }}
- name: Upload AAB to google play
if: github.event_name == 'push' && contains(github.ref, 'refs/tags/')
continue-on-error: true
uses: r0adkll/upload-google-play@v1.0.15
with:
serviceAccountJsonPlainText: ${{ secrets.GOOGLE_PLAY_SERVICE_ACCOUNT_JSON }}
packageName: com.unciv.app
releaseFiles: android/build/outputs/bundle/release/Unciv-release.aab
track: production
userFraction: 0.1
whatsNewDirectory: whatsNewDirectory
- name: Sign APK for Github upload
uses: r0adkll/sign-android-release@v1
continue-on-error: true
if: github.event_name == 'push' && contains(github.ref, 'refs/tags/')
with:
releaseDirectory: android/build/outputs/apk/release
signingKeyBase64: ${{ secrets.BUNDLE_SIGNING_KEY_BASE64 }}
alias: ${{ secrets.BUNDLE_SIGNING_KEY_ALIAS }}
keyStorePassword: ${{ secrets.BUNDLE_SIGNING_KEYSTORE_PASSWORD }}
keyPassword: ${{ secrets.BUNDLE_SIGNING_KEY_PASSWORD }}
- name: Move APK to deploy folder
continue-on-error: true
if: github.event_name == 'push' && contains(github.ref, 'refs/tags/')
shell: bash
run: |
mv android/build/outputs/apk/release/Unciv-release-unsigned-signed.apk Unciv-signed.apk
- name: Upload APK
uses: actions/upload-artifact@v3
with:
name: UncivAPK
path: Unciv-signed.apk
## Finalize
- name: Get AUR PKGBUILD
if: github.event_name == 'push' && contains(github.ref, 'refs/tags/')
continue-on-error: true
run: |
curl --silent --output PKGBUILD 'https://aur.archlinux.org/cgit/aur.git/plain/PKGBUILD?h=unciv-bin'
sed -E -e "s#(_pkgver=).*#\1${{steps.tag.outputs.tag}}#" -e "s#(pkgrel=).*#\10#" -i PKGBUILD
- name: Publish AUR package
if: github.event_name == 'push' && contains(github.ref, 'refs/tags/')
continue-on-error: true
uses: Thyrum/github-actions-deploy-aur@master
with:
pkgname: unciv-bin
pkgbuild: ./PKGBUILD
commit_username: ${{ secrets.AUR_COMMIT_USERNAME }}
commit_email: ${{ secrets.AUR_COMMIT_EMAIL }}
ssh_private_key: ${{ secrets.AUR_SSH_PRIVATE_KEY }}
commit_message: |
Update to ${{steps.tag.outputs.tag}}
${{steps.read_release.outputs.release_body}}
ssh_keyscan_types: rsa,dsa,ecdsa,ed25519
updpkgsums: true
allow_empty_commits: false
packr-build:
if: github.event_name == 'push' && contains(github.ref, 'refs/tags/')
runs-on: ubuntu-latest
needs: Build
steps:
- uses: actions/checkout@v3
- uses: actions/setup-java@v3
with:
distribution: 'temurin'
java-version: '11'
- name: Setup Gradle
uses: gradle/gradle-build-action@v2.3.3
- name: Download JAR
uses: actions/download-artifact@v3
# See 'Upload JAR' step in 'build' job
with:
name: UncivJar
- name: Upload to itch.io
continue-on-error: true
if: github.event_name == 'push' && contains(github.ref, 'refs/tags/')
run: |
mkdir deploy
mkdir -p desktop/build/libs
mv UncivJar/Unciv.jar desktop/build/libs
wget -q -O packr-all-4.0.0.jar https://github.com/libgdx/packr/releases/download/4.0.0/packr-all-4.0.0.jar
wget -q -O jre-linux-64.tar.gz https://github.com/AdoptOpenJDK/openjdk11-binaries/releases/download/jdk-11.0.11%2B9/OpenJDK11U-jre_x64_linux_hotspot_11.0.11_9.tar.gz
./gradlew desktop:packrLinux64
wget -q -O jdk-windows-64.zip https://github.com/ojdkbuild/ojdkbuild/releases/download/java-1.8.0-openjdk-1.8.0.232-1.b09/java-1.8.0-openjdk-1.8.0.232-1.b09.ojdkbuild.windows.x86_64.zip
./gradlew desktop:packrWindows64
- name: Upload packed zips
uses: actions/upload-artifact@v3
with:
name: UncivDeploymentZips
path: |
deploy/Unciv-Windows64.zip
deploy/Unciv-Linux64.zip
Upload-to-itch:
runs-on: ubuntu-latest
needs: packr-build
steps:
- name: Download packed zips
uses: actions/download-artifact@v3
with:
name: UncivDeploymentZips
- name: Upload to itch.io
continue-on-error: true
if: github.event_name == 'push' && contains(github.ref, 'refs/tags/')
env:
BUTLER_API_KEY: ${{ secrets.BUTLER_API_KEY }}
run: |
wget -q -O butler.zip https://broth.itch.ovh/butler/linux-amd64/LATEST/archive/default
unzip butler.zip
chmod +x butler
./butler push Unciv-Linux64.zip yairm210/unciv:Linux64 --userversion ${{needs.Build.outputs.version_tag}}
./butler push Unciv-Windows64.zip yairm210/unciv:Windows64 --userversion ${{needs.Build.outputs.version_tag}}
Upload-to-steam:
runs-on: ubuntu-latest
needs: packr-build
steps:
- name: Download packed zips
uses: actions/download-artifact@v3
with:
name: UncivDeploymentZips
- name: Unzip zips for steam deployment
continue-on-error: true
if: github.event_name == 'push' && contains(github.ref, 'refs/tags/')
shell: bash
run: |
mkdir steam
unzip Unciv-Windows64.zip -d steam/Unciv-Windows64
unzip Unciv-Linux64.zip -d steam/Unciv-Linux64
- name: Steam deploy
continue-on-error: true
if: github.event_name == 'push' && contains(github.ref, 'refs/tags/')
uses: game-ci/steam-deploy@v1
with:
username: ${{ secrets.STEAM_USERNAME }}
password: ${{ secrets.STEAM_PASSWORD }}
configVdf: ${{ secrets.STEAM_CONFIG_VDF}}
ssfnFileName: ${{ secrets.STEAM_SSFN_FILE_NAME }}
ssfnFileContents: ${{ secrets.STEAM_SSFN_FILE_CONTENTS }}
appId: 2118950
buildDescription: ${{steps.tag.outputs.tag}}
rootPath: steam
depot1Path: Unciv-Windows64
depot2Path: Unciv-Linux64
releaseBranch: release
Finalize:
needs: [android-build, packr-build]
runs-on: ubuntu-latest
steps:
- name: Download all artifacts
uses: actions/download-artifact@v3
- name: consolidate deploy folder
run: |
mkdir deploy
mv UncivJar/Unciv.jar deploy
mv UncivJar/linuxFilesForJar.zip deploy
mv UncivDeploymentZips/Unciv-Windows64.zip deploy
mv UncivDeploymentZips/Unciv-Linux64.zip deploy
mv UncivAPK/Unciv-signed.apk deploy
mv UncivServer/UncivServer.jar deploy
- name: Check if this is a real release or a test version, for Github release
id: check-version-tag
run: |
if [[ ${{needs.Build.outputs.version_tag}} =~ [0-9]\.[0-9]+\.[0-9]+ ]]; then
echo "real_release=true" >> $GITHUB_OUTPUT
fi
- name: Upload binaries to Github release
continue-on-error: true
uses: svenstaro/upload-release-action@v2
with:
repo_token: ${{ secrets.GITHUB_TOKEN }}
file: deploy/*
tag: ${{ github.ref }}
prerelease: ${{ steps.check-version-tag.outputs.real_release != 'true' }}
overwrite: true
file_glob: true
# <--- Use environment variables that was created earlier - see https://github.com/svenstaro/upload-release-action
# Single-quotes do not solve the multiline problem.
body: |
## ${{needs.Build.outputs.version_tag}}
${{needs.Build.outputs.release_body}}
- name: Post announcement on Discord
continue-on-error: true
## On patch releases, don't notify Discord
if: github.event_name == 'push' && contains(github.ref, 'refs/tags/') && steps.read_release.outputs.release_body != ''
env:
DISCORD_WEBHOOK: ${{ secrets.DISCORD_WEBHOOK }}
uses: Ilshidur/action-discord@0.3.2
with:
args: | # See https://discordjs.guide/miscellaneous/parsing-mention-arguments.html#how-discord-mentions-work
<@&663705024265715743>
*${{needs.Build.outputs.version_tag}} rolling out!*
${{needs.Build.outputs.release_body}}