Create Insiders Release #511
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: Create Insiders Release | |
on: | |
workflow_dispatch: | |
schedule: | |
- cron: '15 03 * * *' # Every day at 10:15am UTC / 3:15am PT | |
jobs: | |
check_latest: | |
name: Check If Release Is Needed | |
runs-on: ubuntu-20.04 | |
steps: | |
- name: Get last released version | |
id: latest_release | |
uses: thebritican/[email protected] | |
with: | |
repo_path: brimdata/zui-insiders | |
- name: Download last build_sha | |
id: latest_sha | |
run: | | |
curl -L https://github.com/brimdata/zui-insiders/releases/download/${{ steps.latest_release.outputs.tag_name }}/build_sha.txt > build_sha.txt | |
echo "sha=$(cat build_sha.txt)" >> $GITHUB_OUTPUT | |
outputs: | |
version: ${{ steps.latest_release.outputs.tag_name }} | |
latest_sha: ${{ steps.latest_sha.outputs.sha }} | |
release: | |
name: Publish Release | |
needs: check_latest | |
if: ${{ needs.check_latest.outputs.latest_sha != github.sha }} | |
strategy: | |
matrix: | |
# macos-13 is is Intel-based (x64), macos-14 is Apple Silicon (arm64) | |
platform: [windows-2019, macos-13, macos-14, ubuntu-20.04] | |
runs-on: ${{ matrix.platform }} | |
steps: | |
- name: Checkout Zui | |
uses: actions/checkout@v4 | |
- name: Setup Zui | |
uses: ./.github/actions/setup-zui | |
- name: Inject package.json | |
run: yarn nx inject insiders ${{ needs.check_latest.outputs.version }} | |
- name: Disable yarn immutable installs | |
run: yarn config set enableImmutableInstalls false | |
- name: Re-run yarn | |
run: yarn | |
- name: Build Zui | |
uses: ./.github/actions/build-zui | |
with: | |
cmd: yarn nx release-insiders zui | |
gh_token: ${{ secrets.PAT_TOKEN }} | |
# Windows | |
ssl_com_username: ${{ secrets.WINDOWS_SIGNING_SSL_COM_USERNAME }} | |
ssl_com_password: ${{ secrets.WINDOWS_SIGNING_SSL_COM_PASSWORD }} | |
ssl_com_totp_secret: ${{ secrets.WINDOWS_SIGNING_SSL_COM_TOTP_SECRET }} | |
ssl_com_credential_id: ${{ secrets.WINDOWS_SIGNING_SSL_COM_CREDENTIAL_ID }} | |
# Mac | |
apple_id: ${{ secrets.APPLEID_USER }} | |
apple_id_password: ${{ secrets.APPLEID_PASSWORD }} | |
apple_team_id: ${{ secrets.APPLE_TEAM_ID }} | |
cert_p12: ${{ secrets.APPLE_DEVELOPER_ID_CERT_P12_BASE64 }} | |
cert_passphrase: ${{ secrets.APPLE_DEVELOPER_ID_CERT_PASSPHRASE }} | |
- name: Merge latest-mac.yml Mac release files for x64/arm64 | |
if: runner.os == 'macOS' | |
run: | | |
node apps/zui/scripts/merge-mac-release-files.mjs | |
env: | |
GH_TOKEN: ${{ secrets.PAT_TOKEN }} | |
shell: bash | |
- name: Inform Slack users of failure | |
uses: tiloio/[email protected] | |
if: ${{ failure() }} | |
with: | |
slack_web_hook_url: ${{ secrets.SLACK_WEBHOOK_BRIMLABS_TEST }} | |
slack_json: | | |
{ | |
"username": "{{GITHUB_REPOSITORY}}", | |
"text": "Release failed: https://github.com/{{GITHUB_REPOSITORY}}/actions/runs/{{GITHUB_RUN_ID}}" | |
} | |
record_build_sha: | |
needs: release | |
name: Upload the Build Sha | |
runs-on: ubuntu-20.04 | |
steps: | |
- name: Create the build_sha file | |
run: echo ${{ github.sha }} > build_sha.txt | |
- name: Get the just released tag | |
id: just_released | |
uses: thebritican/[email protected] | |
with: | |
repo_path: brimdata/zui-insiders | |
- name: Upload build_sha file to the latest release | |
uses: svenstaro/upload-release-action@v2 | |
with: | |
file: build_sha.txt | |
tag: ${{ steps.just_released.outputs.tag_name }} | |
repo_name: brimdata/zui-insiders | |
repo_token: ${{ secrets.PAT_TOKEN }} | |
overwrite: true |