synchronize ci/main

This commit is contained in:
Jacob Heider 2023-01-20 18:31:44 -05:00
parent aef0e2a2a1
commit 42cf0fc54c
No known key found for this signature in database
GPG key ID: A98011B5713535BF
2 changed files with 199 additions and 122 deletions

View file

@ -120,99 +120,167 @@ jobs:
# name: linux+aarch64 # name: linux+aarch64
container: ${{ matrix.platform.container }} container: ${{ matrix.platform.container }}
steps: steps:
- uses: actions/checkout@v3 - uses: actions/checkout@v3
- uses: teaxyz/setup@v0
if: startsWith(matrix.platform.name, 'darwin')
- name: build tauri for MacOS - name: build tauri for MacOS
# uses: teaxyz/setup@v0 if: startsWith(matrix.platform.name, 'darwin')
if: startsWith(matrix.platform.name, 'darwin') # FROM: https://tauri.app/v1/guides/distribution/sign-macos
# FROM: https://tauri.app/v1/guides/distribution/sign-macos env:
env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} ENABLE_CODE_SIGNING: ${{ secrets.GUI_APPLE_CERTIFICATE }}
ENABLE_CODE_SIGNING: ${{ secrets.GUI_APPLE_CERTIFICATE }} APPLE_CERTIFICATE: ${{ secrets.GUI_APPLE_CERTIFICATE }}
APPLE_CERTIFICATE: ${{ secrets.GUI_APPLE_CERTIFICATE }} APPLE_CERTIFICATE_PASSWORD: ${{ secrets.GUI_APPLE_CERTIFICATE_PASSWORD }}
APPLE_CERTIFICATE_PASSWORD: ${{ secrets.GUI_APPLE_CERTIFICATE_PASSWORD }} APPLE_SIGNING_IDENTITY: ${{ secrets.APPLE_SIGNING_IDENTITY }}
APPLE_SIGNING_IDENTITY: ${{ secrets.APPLE_SIGNING_IDENTITY }} run: tea -ES xc build
# TODO: uncomment once isolated m1 runner is setup with latest xcode
# only used for notarization
# APPLE_ID: ${{ secrets.APPLE_ID }}
# APPLE_PASSWORD: ${{ secrets.APPLE_PASSWORD }}
run: |
sh <(curl https://tea.xyz) -ES xc build
- name: build tauri for Linux - name: build tauri for Linux
# uses: teaxyz/setup@v0 if: startsWith(matrix.platform.name, 'linux')
if: startsWith(matrix.platform.name, 'linux') # TODO: https://tauri.app/v1/guides/distribution/sign-linux
# TODO: https://tauri.app/v1/guides/distribution/sign-linux uses: docker://getneil/tea-builder:latest
uses: docker://getneil/tea-builder:latest
- name: build platform output
id: build_platform
env:
platform: ${{ matrix.platform.name }}
run: |
EXTENSION=dmg
BUILD_PLATFORM=$(echo $platform | sed -e "s/darwin+//g" | sed -e "s/linux+//g")
[[ $BUILD_PLATFORM = "x86-64" ]] && BUILD_PLATFORM="x64" || BUILD_PLATFORM=$BUILD_PLATFORM
[[ $platform = "linux+x86-64" ]] && BUILD_PLATFORM="amd64" || BUILD_PLATFORM=$BUILD_PLATFORM
[[ $platform = "linux+x86-64" ]] && EXTENSION="deb"
echo "build_platform=$BUILD_PLATFORM" >> $GITHUB_OUTPUT
echo "extension=$EXTENSION" >> $GITHUB_OUTPUT
- name: zip .app for MacOS - run: >
if: matrix.platform.name == 'darwin+x86-64' || matrix.platform.name == 'darwin+aarch64' tar -czvf artifacts.tgz
run: | -C ./modules/gui/src-tauri/target/release/bundle .
cd ./modules/gui/src-tauri/target/release/bundle/macos/ && zip -r tea.zip tea.app
- uses: aws-actions/configure-aws-credentials@v1 - name: upload artifacts
with: uses: actions/upload-artifact@v3
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} with:
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} name: ${{ matrix.platform.name }}
aws-region: us-east-1 path: artifacts.tgz
if-no-files-found: error
- name: cp package images from prod to preview bucket notorize_tauri:
env: needs: [build_tauri]
prefix: ${{ needs.changes.outputs.preview_folder }} runs-on: macos-11
platform: ${{ steps.build_platform.outputs.build_platform }} strategy:
extension: ${{ steps.build_platform.outputs.extension }} matrix:
run: | platform:
aws s3 cp "./modules/gui/src-tauri/target/release/bundle/$extension/tea_0.1.0_$platform.$extension" \ - darwin+x86-64
"s3://preview.gui.tea.xyz/$prefix/tea_$platform.$extension" - darwin+aarch64
steps:
- name: cp package zip for MacOS - uses: actions/download-artifact@v3
if: matrix.platform.name == 'darwin+x86-64' || matrix.platform.name == 'darwin+aarch64' with:
env: name: ${{ matrix.platform }}
prefix: ${{ needs.changes.outputs.preview_folder }}
platform: ${{ steps.build_platform.outputs.build_platform }}
run: |
aws s3 cp ./modules/gui/src-tauri/target/release/bundle/macos/tea.zip "s3://preview.gui.tea.xyz/$prefix/tea_$platform.zip"
- name: comment install for Linux - run: tar xzf artifacts.tgz
if: startsWith(matrix.platform.name, 'linux')
uses: mshick/add-pr-comment@v2
with:
message-id: ${{ matrix.platform.id }}-comment
message: |
**installer for Linux ${{ matrix.platform.name }} is at**:
<a href="http://preview.gui.tea.xyz.s3-website-us-east-1.amazonaws.com/${{ needs.changes.outputs.preview_folder }}/tea_${{steps.build_platform.outputs.build_platform}}.${{steps.build_platform.outputs.extension}}" target="_blank">here</a>
```bash - run: cd ./macos/ && zip -r tea.zip tea.app
http://preview.gui.tea.xyz.s3-website-us-east-1.amazonaws.com/${{ needs.changes.outputs.preview_folder }}/tea_${{ steps.build_platform.outputs.build_platform }}.${{ steps.build_platform.outputs.extension }}
```
copy-paste into a browser to download
- name: comment install for MacOS # Notarize. Can take up to 10 minutes (and fail) asynchronously
if: startsWith(matrix.platform.name, 'darwin') - run: xcrun altool --notarize-app --username "$APPLE_ID" --password "$APPLE_PASSWORD" --primary-bundle-id "com.tea.xyz" --file ./macos/tea.zip
uses: mshick/add-pr-comment@v2 env:
with: APPLE_ID: ${{ secrets.APPLE_ID }}
message-id: ${{ matrix.platform.id }}-comment APPLE_PASSWORD: ${{ secrets.APPLE_PASSWORD }}
message: |
**installers for MacOS ${{ matrix.platform.name }} is at**:
<a href="http://preview.gui.tea.xyz.s3-website-us-east-1.amazonaws.com/${{ needs.changes.outputs.preview_folder }}/tea_${{steps.build_platform.outputs.build_platform}}.zip" target="_blank">.zip</a>
or
<a href="http://preview.gui.tea.xyz.s3-website-us-east-1.amazonaws.com/${{ needs.changes.outputs.preview_folder }}/tea_${{steps.build_platform.outputs.build_platform}}.dmg" target="_blank">.dmg</a>
```bash upload:
http://preview.gui.tea.xyz.s3-website-us-east-1.amazonaws.com/${{ needs.changes.outputs.preview_folder }}/tea_${{ steps.build_platform.outputs.build_platform }}.zip needs: [build_tauri, notorize_tauri]
http://preview.gui.tea.xyz.s3-website-us-east-1.amazonaws.com/${{ needs.changes.outputs.preview_folder }}/tea_${{ steps.build_platform.outputs.build_platform }}.dmg runs-on: ubuntu-latest
``` strategy:
copy-paste into a browser to download matrix:
platform:
- darwin+x86-64
- linux+x86-64
- darwin+aarch64
# - linux+aarch64
steps:
- uses: actions/download-artifact@v3
with:
name: ${{ matrix.platform }}
- run: tar xzf artifacts.tgz
- name: build platform output
id: build_platform
env:
platform: ${{ matrix.platform }}
run: |
BUILD_PLATFORM=$(echo $platform | sed -e "s/darwin+//g" | sed -e "s/linux+//g")
EXTENSION=dmg
case $platform in
"linux+x86-64")
BUILD_PLATFORM="amd64"
EXTENSION="deb"
;;
"linux+aarch64")
BUILD_PLATFORM="aarch64"
EXTENSION="deb"
;;
"darwin+aarch64")
BUILD_PLATFORM="aarch64"
EXTENSION="dmg"
;;
"darwin+x86-64")
BUILD_PLATFORM="x64"
EXTENSION="dmg"
;;
*)
echo "Unknown platform $platform"
exit 1
;;
esac
echo "build_platform=$BUILD_PLATFORM" >> $GITHUB_OUTPUT
echo "extension=$EXTENSION" >> $GITHUB_OUTPUT
- name: zip .app for MacOS
if: startsWith(matrix.platform, 'darwin+')
run: |
cd ./modules/gui/src-tauri/target/release/bundle/macos/
zip -r tea.zip tea.app
- uses: aws-actions/configure-aws-credentials@v1
with:
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }}
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
aws-region: us-east-1
- name: cp package images from prod to preview bucket
env:
prefix: ${{ needs.changes.outputs.preview_folder }}
platform: ${{ steps.build_platform.outputs.build_platform }}
extension: ${{ steps.build_platform.outputs.extension }}
run: >
aws s3 cp
"./modules/gui/src-tauri/target/release/bundle/$extension/tea_0.1.0_$platform.$extension"
"s3://preview.gui.tea.xyz/$prefix/tea_$platform.$extension"
- name: cp package zip for MacOS
if: matrix.platform.name == 'darwin+x86-64' || matrix.platform.name == 'darwin+aarch64'
env:
prefix: ${{ needs.changes.outputs.preview_folder }}
platform: ${{ steps.build_platform.outputs.build_platform }}
run: >
aws s3 cp
./modules/gui/src-tauri/target/release/bundle/macos/tea.zip "s3://preview.gui.tea.xyz/$prefix/tea_$platform.zip"
- name: comment install for Linux
if: startsWith(matrix.platform.name, 'linux')
uses: mshick/add-pr-comment@v2
with:
message-id: ${{ matrix.platform.id }}-comment
message: |
**installer for Linux ${{ matrix.platform.name }} is at**:
<a href="http://preview.gui.tea.xyz.s3-website-us-east-1.amazonaws.com/${{ needs.changes.outputs.preview_folder }}/tea_${{steps.build_platform.outputs.build_platform}}.${{steps.build_platform.outputs.extension}}" target="_blank">here</a>
```bash
http://preview.gui.tea.xyz.s3-website-us-east-1.amazonaws.com/${{ needs.changes.outputs.preview_folder }}/tea_${{ steps.build_platform.outputs.build_platform }}.${{ steps.build_platform.outputs.extension }}
```
copy-paste into a browser to download
- name: comment install for MacOS
if: startsWith(matrix.platform.name, 'darwin')
uses: mshick/add-pr-comment@v2
with:
message-id: ${{ matrix.platform.id }}-comment
message: |
**installers for MacOS ${{ matrix.platform.name }} is at**:
<a href="http://preview.gui.tea.xyz.s3-website-us-east-1.amazonaws.com/${{ needs.changes.outputs.preview_folder }}/tea_${{steps.build_platform.outputs.build_platform}}.zip" target="_blank">.zip</a>
or
<a href="http://preview.gui.tea.xyz.s3-website-us-east-1.amazonaws.com/${{ needs.changes.outputs.preview_folder }}/tea_${{steps.build_platform.outputs.build_platform}}.dmg" target="_blank">.dmg</a>
```bash
http://preview.gui.tea.xyz.s3-website-us-east-1.amazonaws.com/${{ needs.changes.outputs.preview_folder }}/tea_${{ steps.build_platform.outputs.build_platform }}.zip
http://preview.gui.tea.xyz.s3-website-us-east-1.amazonaws.com/${{ needs.changes.outputs.preview_folder }}/tea_${{ steps.build_platform.outputs.build_platform }}.dmg
```
copy-paste into a browser to download

View file

@ -76,8 +76,9 @@ jobs:
# TODO: https://tauri.app/v1/guides/distribution/sign-linux # TODO: https://tauri.app/v1/guides/distribution/sign-linux
uses: docker://getneil/tea-builder:latest uses: docker://getneil/tea-builder:latest
- run: | - run: >
tar -czvf artifacts.tgz -C ./modules/gui/src-tauri/target/release/bundle . tar -czvf artifacts.tgz
-C ./modules/gui/src-tauri/target/release/bundle .
- name: upload artifacts - name: upload artifacts
uses: actions/upload-artifact@v3 uses: actions/upload-artifact@v3
@ -168,38 +169,46 @@ jobs:
echo "build_platform=$BUILD_PLATFORM" >> $GITHUB_OUTPUT echo "build_platform=$BUILD_PLATFORM" >> $GITHUB_OUTPUT
echo "extension=$EXTENSION" >> $GITHUB_OUTPUT echo "extension=$EXTENSION" >> $GITHUB_OUTPUT
# - name: cp package images from prod to gui bucket - name: zip .app for MacOS
# env: if: startsWith(matrix.platform, 'darwin+')
# platform: ${{ steps.build_platform.outputs.build_platform }} run: |
# build_platform: ${{ matrix.platform }} cd ./modules/gui/src-tauri/target/release/bundle/macos/
# extension: ${{steps.build_platform.outputs.extension}} zip -r tea.zip tea.app
# run: |
# aws s3 cp "./$extension/tea_0.1.0_$platform.$extension" \
# "s3://preview.gui.tea.xyz/release/tea_${{ steps.date.outputs.unix_seconds }}_$platform.$extension"
# - name: cp package zip for MacOS - name: cp package images from prod to gui bucket
# if: startsWith(matrix.platform, 'darwin') env:
# env: platform: ${{ steps.build_platform.outputs.build_platform }}
# platform: ${{ steps.build_platform.outputs.build_platform }} build_platform: ${{ matrix.platform }}
# build_platform: ${{ matrix.platform }} extension: ${{steps.build_platform.outputs.extension}}
# run: | run: >
# aws s3 cp ./macos/tea.zip "s3://preview.gui.tea.xyz/release/tea_${{ steps.date.outputs.unix_seconds }}_$platform.zip" aws s3 cp
# - uses: actions/setup-node@v3 "./$extension/tea_0.1.0_$platform.$extension"
# with: "s3://preview.gui.tea.xyz/release/tea_${{ steps.date.outputs.unix_seconds }}_$platform.$extension"
# node-version: 18
# - name: Slack Notification
# run: ./.github/notify-slack.js
# env:
# SLACK_WEBHOOK: ${{ secrets.SLACK_WEBHOOK }}
# PLATFORM: ${{ matrix.platform }}
# EXT: ${{ steps.build_platform.outputs.extension }}
# DOWNLOAD_URL: http://preview.gui.tea.xyz.s3-website-us-east-1.amazonaws.com/release/tea_${{ steps.date.outputs.unix_seconds }}_${{ steps.build_platform.outputs.build_platform }}.${{ steps.build_platform.outputs.extension }}
# - name: Slack Notification for .app Mac - name: cp package zip for MacOS
# run: ./.github/notify-slack.js if: startsWith(matrix.platform, 'darwin')
# if: startsWith(matrix.platform, 'darwin') env:
# env: platform: ${{ steps.build_platform.outputs.build_platform }}
# SLACK_WEBHOOK: ${{ secrets.SLACK_WEBHOOK }} build_platform: ${{ matrix.platform }}
# PLATFORM: ${{ matrix.platform }} run: >
# EXT: .zip(.app) aws s3 cp ./macos/tea.zip
# DOWNLOAD_URL: http://preview.gui.tea.xyz.s3-website-us-east-1.amazonaws.com/release/tea_${{ steps.date.outputs.unix_seconds }}_${{ steps.build_platform.outputs.build_platform }}.zip "s3://preview.gui.tea.xyz/release/tea_${{ steps.date.outputs.unix_seconds }}_$platform.zip"
- uses: actions/setup-node@v3
with:
node-version: 18
- name: Slack Notification
run: ./.github/notify-slack.js
env:
SLACK_WEBHOOK: ${{ secrets.SLACK_WEBHOOK }}
PLATFORM: ${{ matrix.platform }}
EXT: ${{ steps.build_platform.outputs.extension }}
DOWNLOAD_URL: http://preview.gui.tea.xyz.s3-website-us-east-1.amazonaws.com/release/tea_${{ steps.date.outputs.unix_seconds }}_${{ steps.build_platform.outputs.build_platform }}.${{ steps.build_platform.outputs.extension }}
- name: Slack Notification for .app Mac
run: ./.github/notify-slack.js
if: startsWith(matrix.platform, 'darwin')
env:
SLACK_WEBHOOK: ${{ secrets.SLACK_WEBHOOK }}
PLATFORM: ${{ matrix.platform }}
EXT: .zip(.app)
DOWNLOAD_URL: http://preview.gui.tea.xyz.s3-website-us-east-1.amazonaws.com/release/tea_${{ steps.date.outputs.unix_seconds }}_${{ steps.build_platform.outputs.build_platform }}.zip