Skip to content

Merge branch 'master' into release-config #98

Merge branch 'master' into release-config

Merge branch 'master' into release-config #98

Workflow file for this run

name: Release
on:
push:
tags:
- '*'
env:
# GCS_BUCKET is the name of the Google Cloud Storage bucket to which all artifacts are deployed.
GCS_BUCKET: mitbattlecode-releases
# RELEASE_ARTIFACT_ID is the name of the Maven artifact produced by the buildsystem.
# Important: you must make sure no ID is a prefix of a different ID. Otherwise, you could
# inadvertently cause unintended episodes to become public.
RELEASE_ARTIFACT_ID: battlecode24
# IS_PUBLIC is whether to release deployments publicly. Set to exactly the text "YES" to do so.
IS_PUBLIC: YES
jobs:
build-client:
name: Build client
permissions:
contents: read
id-token: write
strategy:
matrix:
include:
- platform-name: "macos-latest"
build-name: "macos"
tauri-target: "universal-apple-darwin"
tauri-copy-path: "bundle/macos/*.app"
- platform-name: "ubuntu-latest"
build-name: "linux"
tauri-target: "x86_64-unknown-linux-gnu"
tauri-copy-path: "bundle/appimage/*.AppImage"
upload-dist: true
- platform-name: "windows-latest"
build-name: "windows"
tauri-target: "x86_64-pc-windows-msvc"
tauri-copy-path: "*.exe"
runs-on: ${{ matrix.platform-name }}
env:
TAURI_OUTPUT: ./src-tauri/target/${{ matrix.tauri-target }}/release/${{ matrix.tauri-copy-path }}
TAURI_BUILD_COMMAND: npm run tauri-pack -- -t ${{ matrix.tauri-target }}
ELECTRON_BUILD_COMMAND: npm run electron-pack
steps:
- name: Checkout branch
uses: actions/checkout@v3
- name: Set up Node 16
uses: actions/setup-node@v3
with:
node-version: 16
# Rust toolchain is preinstalled on runner images, but we need to add the arm64
# toolchain on macos to compile universal apps from the x86 runner
- name: Install macos dependencies
if: startsWith(matrix.platform-name, 'macos')
run: |
rustup target add aarch64-apple-darwin
npm install @tauri-apps/cli-darwin-x64
- name: Install linux dependencies
if: startsWith(matrix.platform-name, 'ubuntu')
run: |
sudo apt-get update
sudo apt-get install -y libwebkit2gtk-4.0-dev build-essential wget libssl-dev libgtk-3-dev libayatana-appindicator3-dev librsvg2-dev
npm install @tauri-apps/cli-linux-x64-gnu
- name: Install windows dependencies
if: startsWith(matrix.platform-name, 'windows')
run: npm install @tauri-apps/cli-win32-x64-msvc
- name: Install schema
run: npm install
working-directory: ./schema
- name: Install client
run: npm install
working-directory: ./client
- name: Build client webpack
run: npm run build
working-directory: ./client
- name: Build client applications
run: npm run concurrently -- --kill-others-on-fail "${{ env.ELECTRON_BUILD_COMMAND }}" "${{ env.TAURI_BUILD_COMMAND }}"
working-directory: ./client
# 7-zip is preinstalled on runner images
- name: Zip tauri result
run: 7z a packaged-client/tauri-output.zip "${{ env.TAURI_OUTPUT }}"
working-directory: ./client
# Only need to create this artifact on one job since all platforms produce
# the same result
- name: Upload dist files artifact
if: matrix.upload-dist
uses: actions/upload-artifact@v3
with:
name: client-dist
path: ./client/dist
- name: Upload client artifact
uses: actions/upload-artifact@v3
with:
name: client-${{ matrix.build-name }}
path: |
./client/packaged-client/*-output.zip
release:
name: Release
runs-on: ubuntu-latest
needs: build-client
permissions:
contents: read
id-token: write
actions: write # To cleanup artifacts
steps:
- name: Checkout branch
uses: actions/checkout@v3
- name: Inject release version
run: |
release_version=${GITHUB_REF#refs/*/}
echo "RELEASE_VERSION=$release_version" >> $GITHUB_ENV
echo "The release version is $release_version"
- name: Authenticate to Google Cloud Platform
uses: google-github-actions/auth@v1
with:
create_credentials_file: true
workload_identity_provider: projects/830784087321/locations/global/workloadIdentityPools/releases/providers/github-workflow
service_account: [email protected]
- name: Set up Google Cloud SDK
uses: 'google-github-actions/setup-gcloud@v1'
- name: Clone private maps
if: ${{ env.IS_PUBLIC != 'YES' }}
uses: actions/checkout@v3
with:
repository: battlecode/private-maps
token: ${{ secrets.CI_REPOSITORY_CLONE_PAT }}
path: private-maps
- name: Inject private maps
if: ${{ env.IS_PUBLIC != 'YES' }}
run: |
source="private-maps/$RELEASE_ARTIFACT_ID"
dest="engine/src/main/battlecode/world/resources"
if [ -d "$source" ]; then
cp -r -i "$source/." "$dest/" < /dev/null &> private-maps-copy-log
if [ -s "private-maps-copy-log" ]; then
echo "FAILED! Public and private maps should not intersect."
cat private-maps-copy-log
exit 1
fi
fi
- name: Set up JDK 8
uses: actions/setup-java@v3
with:
java-version: 8
distribution: adopt
- name: Download all client artifacts
uses: actions/download-artifact@v3
with:
path: ./client/artifacts
# Always cleanup even if other commands failed so we don't unnecessarily store
# the artifacts in the cloud
- name: Cleanup client artifacts
uses: geekyeggo/delete-artifact@54ab544f12cdb7b71613a16a2b5a37a9ade990af
if: always()
with:
name: client-*
- name: Publish to local repository
run: ./gradlew publishToMavenLocal -Prelease_version=$RELEASE_VERSION
- name: Determine access control
run: |
[[ "$IS_PUBLIC" = "YES" ]] && acl="public-read" || acl="project-private"
echo "OBJECT_ACL=$acl" >> $GITHUB_ENV
echo "Objects will be uploaded with ACL $acl"
- name: Upload maven artifacts to remote repository
run: gsutil -m rsync -a $OBJECT_ACL -r $HOME/.m2/repository/org/battlecode gs://$GCS_BUCKET/maven/org/battlecode
- name: Upload javadocs
run: |
unzip -d ${{ runner.temp }}/javadoc $HOME/.m2/repository/org/battlecode/$RELEASE_ARTIFACT_ID/$RELEASE_VERSION/*-javadoc.jar
gsutil -m rsync -a $OBJECT_ACL -r ${{ runner.temp }}/javadoc gs://$GCS_BUCKET/javadoc/$RELEASE_ARTIFACT_ID/$RELEASE_VERSION
- name: Upload specs
run: gsutil -m rsync -a $OBJECT_ACL -r ./specs gs://$GCS_BUCKET/specs/$RELEASE_ARTIFACT_ID/$RELEASE_VERSION
- name: Upload web client
run: |
gsutil -m rsync -r -a $OBJECT_ACL ./artifacts/client-dist gs://$GCS_BUCKET/client/$RELEASE_ARTIFACT_ID/$RELEASE_VERSION
working-directory: ./client