ci: add/update workflow for autosquash on PRs #9
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: Publish | |
on: | |
push: | |
branches: | |
- master | |
workflow_dispatch: {} | |
concurrency: | |
# only run one publishing at a time to avoid conflicts | |
group: publish-${{ github.ref }} | |
# env: | |
# instead of embedded Maven use local Maven CLI | |
# HALE_BUILD_MAVEN_EMBEDDED: 'false' | |
jobs: | |
build: | |
# Only on main repository (don't publish on forks) | |
if: github.repository_owner == 'halestudio' | |
runs-on: ubuntu-latest | |
steps: | |
- name: Setup Maven | |
uses: s4u/setup-maven-action@489441643219d2b93ee2a127b2402eb640a1b947 # v1.13.0 | |
# uses: stempler/setup-maven-action@feat/cache-save-always | |
with: | |
java-version: 17 | |
java-distribution: temurin | |
maven-version: 3.9.6 | |
# Note: currently not working because of https://github.com/actions/cache/issues/1315 | |
# Fix in https://github.com/actions/cache/pull/1325 not merged yet | |
# cache-save-always: true | |
- name: Install genisoimage # required for Mac build | |
run: sudo apt-get install -y genisoimage | |
- name: Login to Docker Hub | |
uses: docker/login-action@0d4c9c5ea7693da7b068278f7b52bda2a190a446 # v3.2.0 | |
with: | |
username: ${{ secrets.DOCKER_HUB_USERNAME }} | |
password: ${{ secrets.DOCKER_HUB_PASSWORD }} | |
- name: Clean | |
run: ./build.sh clean | |
working-directory: ./build | |
- name: Create hale-docker.conf file | |
run: | | |
mkdir -p ~/.hale | |
cat <<EOF > ~/.hale/hale-docker.conf | |
global { | |
dockerHost="unix:///var/run/docker.sock" | |
} | |
EOF | |
- name: Test | |
run: ./build.sh integrationStage | |
working-directory: ./build | |
- name: Product | |
run: | | |
./build.sh product --arch x86_64 --os linux HALE | |
./build.sh product --arch x86_64 --os windows HALE | |
./build.sh product --arch x86_64 --os macosx HALE | |
./build.sh product --arch x86_64 --os linux --publish Infocenter | |
working-directory: ./build | |
- name: Upload hale studio build (Linux) | |
uses: actions/upload-artifact@65462800fd760344b1a7b4382951275a0abb4808 # v4.3.3 | |
with: | |
name: hale studio (Linux) | |
path: build/target/hale-studio-*linux*.tar.gz | |
retention-days: 90 | |
- name: Upload hale studio build (Windows) | |
uses: actions/upload-artifact@65462800fd760344b1a7b4382951275a0abb4808 # v4.3.3 | |
with: | |
name: hale studio (Windows) | |
path: build/target/hale-studio-*win32*.zip | |
retention-days: 90 | |
- name: Upload hale studio build (macos) | |
uses: actions/upload-artifact@65462800fd760344b1a7b4382951275a0abb4808 # v4.3.3 | |
with: | |
name: hale studio (macos) | |
path: build/target/hale-studio-*macosx*.dmg | |
retention-days: 90 | |
- name: Install AWS CLI | |
uses: unfor19/install-aws-cli-action@e8b481e524a99f37fbd39fdc1dcb3341ab091367 # v1.0.7 | |
with: | |
version: 1 | |
- name: Update site | |
env: | |
AWS_ACCESS_KEY_ID: ${{ secrets.BUILD_ARCHIVE_ACCESS_KEY }} | |
AWS_SECRET_ACCESS_KEY: ${{ secrets.BUILD_ARCHIVE_SECRET_KEY }} | |
run: ./upload-site.sh | |
working-directory: ./build | |
- name: Deploy Artifacts | |
env: | |
WETF_ARTIFACTORY_USER: ${{ secrets.WETF_ARTIFACTORY_USER }} | |
WETF_ARTIFACTORY_PASSWORD: ${{ secrets.WETF_ARTIFACTORY_PASSWORD }} | |
JAVA_TOOL_OPTIONS: '-Dmaven.wagon.httpconnectionManager.ttlSeconds=120' | |
run: ./build.sh deployArtifacts | |
working-directory: ./build | |
- name: Publish Test Report | |
uses: mikepenz/action-junit-report@ac30be7acb0a361e5492575ab42e47fcadec4928 # v4.2.2 | |
if: always() # always run even if the previous step fails | |
with: | |
# fail if there are no test results | |
require_tests: true | |
# Workaround for check that is additionally created being associated | |
# to the wrong workflow/run. Instead no additional check is created. | |
# See https://github.com/mikepenz/action-junit-report/issues/40 | |
annotate_only: true | |
detailed_summary: true | |
report_paths: 'build/target/testReports/*.xml' | |
# https://github.com/marketplace/actions/slack-notify-build | |
- name: Notify failure to Slack | |
if: failure() | |
env: | |
SLACK_BOT_TOKEN: ${{ secrets.SLACK_NOTIFICATIONS_BOT_TOKEN }} | |
uses: voxmedia/github-action-slack-notify-build@3665186a8c1a022b28a1dbe0954e73aa9081ea9e # v1.6.0 | |
with: | |
channel: build-failures | |
status: FAILED | |
color: danger |