chore(deps): update s4u/setup-maven-action action to v1.16.0 #190
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@382542f77617f34e56bf83868920a4d45b7451e7 # v1.16.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@9780b0c442fbb1117ed29e0efdff1e18412f7567 # v3.3.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 commitStage # integrationStage no longer working due to outdated Docker client, tests are performed in hale-core | |
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@b4b15b8c7c6ac21ea08fcf65892d2ee8f75cf882 # v4.4.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@b4b15b8c7c6ac21ea08fcf65892d2ee8f75cf882 # v4.4.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@b4b15b8c7c6ac21ea08fcf65892d2ee8f75cf882 # v4.4.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@992d97d6eb2e5f3de985fbf9df6a04386874114d # v5.1.0 | |
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 | |
trivy: | |
needs: [build] | |
runs-on: ubuntu-latest | |
steps: | |
- name: Download hale studio build (Linux) | |
uses: actions/download-artifact@fa0a91b85d4f404e444e00e005971372dc801d16 # v4.1.8 | |
with: | |
name: hale studio (Linux) | |
- name: Extract the archive file | |
run: | | |
mkdir -p hale-studio-linux-trivy | |
tar -xzf hale-studio-*linux*.tar.gz -C hale-studio-linux-trivy | |
- name: Run Trivy vulnerability scanner in rootfs mode | |
uses: aquasecurity/trivy-action@master | |
with: | |
scan-type: 'rootfs' | |
scan-ref: 'hale-studio-linux-trivy' | |
format: 'sarif' | |
severity: 'CRITICAL,HIGH' | |
output: 'trivy-results.sarif' | |
- name: Upload Trivy SARIF report | |
uses: github/codeql-action/upload-sarif@aa578102511db1f4524ed59b8cc2bae4f6e88195 # v3.27.6 | |
with: | |
sarif_file: trivy-results.sarif |