name: "test" on: [pull_request] jobs: changes: runs-on: ubuntu-latest outputs: svelte: ${{steps.svelte.outputs.src}} tauri: ${{steps.tauri.outputs.src}} preview_folder: ${{steps.preview.outputs.folder}} steps: - uses: actions/checkout@v3 - uses: dorny/paths-filter@v2 id: svelte with: filters: | src: - 'modules/gui/src/**' - 'modules/ui/**' - uses: dorny/paths-filter@v2 id: tauri with: filters: | src: - 'modules/gui/src-tauri/**' - 'modules/gui/src/**' - 'modules/ui/src/**' - name: get s3 preview folder id: preview run: echo "folder=${{ github.event.number }}-merge" >> $GITHUB_OUTPUT no_preview: needs: changes if: needs.changes.outputs.svelte == 'false' runs-on: ubuntu-latest steps: - name: comment preview site uses: mshick/add-pr-comment@v2 with: message-id: preview-comment-${{needs.changes.outputs.preview_folder}} message: | no preview or changes related to UI test: needs: changes runs-on: ubuntu-latest steps: - uses: actions/checkout@v3 with: persist-credentials: false - uses: pnpm/action-setup@v2 with: version: 7 - name: setup node uses: actions/setup-node@v1 with: node-version: 18 cache: 'pnpm' cache-dependency-path: pnpm-lock.yaml - name: install app dependencies run: pnpm install - name: lint run: pnpm -r lint build_svelte: needs: changes if: needs.changes.outputs.svelte == 'true' runs-on: ubuntu-latest steps: - uses: actions/checkout@v3 with: persist-credentials: false - uses: pnpm/action-setup@v2 with: version: 7 - name: setup node uses: actions/setup-node@v1 with: node-version: 18 cache: 'pnpm' cache-dependency-path: pnpm-lock.yaml - name: install Rust stable uses: actions-rs/toolchain@v1 with: toolchain: stable - name: install app dependencies and build it env: BUILD_FOR: preview run: pnpm install && pnpm --filter gui build - 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: sync web files into preview folder env: prefix: ${{ needs.changes.outputs.preview_folder }} run: | aws s3 sync ./modules/gui/build \ "s3://preview.gui.tea.xyz/$prefix" - name: Install package run: sudo apt-get install -y jq coreutils - name: setup preview id: preview_setup run: .github/create-invalidate-preview.sh ${{ needs.changes.outputs.preview_folder }} - name: comment preview site uses: mshick/add-pr-comment@v2 with: message-id: preview-comment-${{needs.changes.outputs.preview_folder}} message: | **preview is at**: [https://${{steps.preview_setup.outputs.domain}}](https://${{steps.preview_setup.outputs.domain}}) ```bash https://${{steps.preview_setup.outputs.domain}} ``` copy-paste into a browser to view build_tauri: needs: changes if: needs.changes.outputs.tauri == 'true' runs-on: ${{ matrix.platform.os }} strategy: matrix: platform: - os: macos-11 name: darwin+x86-64 - os: ubuntu-latest name: linux+x86-64 - os: [self-hosted, macOS, ARM64] name: darwin+aarch64 # - os: [self-hosted, linux, ARM64] # name: linux+aarch64 container: ${{ matrix.platform.container }} steps: - uses: actions/checkout@v2 - uses: pnpm/action-setup@v2 with: version: 7 - name: setup node uses: actions/setup-node@v1 with: node-version: 18 cache: 'pnpm' cache-dependency-path: pnpm-lock.yaml - name: install Rust stable uses: actions-rs/toolchain@v1 with: toolchain: stable - name: install app dependencies run: pnpm install - name: install dependencies (ubuntu only) if: matrix.platform.name == 'linux+x86-64' run: | sudo apt-get update sudo apt-get install -y libgtk-3-dev webkit2gtk-4.0 libappindicator3-dev librsvg2-dev patchelf pkg-config - uses: Swatinem/rust-cache@v2 with: # The prefix cache key, this can be changed to start a new cache manually. # default: "v0-rust" prefix-key: ${{ matrix.platform.name }} shared-key: ci cache-targets: false - name: Cache Tauri Target uses: actions/cache@v3 with: path: | ./modules/gui/src-tauri/target key: ${{ matrix.platform.name }}-build-target restore-keys: | ${{ matrix.platform.name }}-build-target - 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 # - uses: apple-actions/import-codesign-certs@d54750db52a4d3eaed0fc107a8bab3958f3f7494 # if: matrix.platform.name == 'darwin+x86-64' || matrix.platform.name == 'darwin+aarch64' # with: # p12-file-base64: ${{ secrets.APPLE_CERTIFICATE_P12 }} # p12-password: ${{ secrets.APPLE_CERTIFICATE_P12_PASSWORD }} - name: test build tauri for MacOS if: matrix.platform.name == 'darwin+x86-64' || matrix.platform.name == 'darwin+aarch64' # FROM: https://tauri.app/v1/guides/distribution/sign-macos env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} ENABLE_CODE_SIGNING: ${{ secrets.APPLE_CERTIFICATE_P12 }} APPLE_CERTIFICATE: ${{ secrets.APPLE_CERTIFICATE_P12 }} APPLE_CERTIFICATE_PASSWORD: ${{ secrets.APPLE_CERTIFICATE_P12_PASSWORD }} APPLE_SIGNING_IDENTITY: ${{ secrets.APPLE_SIGNING_IDENTITY }} APPLE_ID: ${{ secrets.APPLE_ID }} APPLE_PASSWORD: ${{ secrets.APPLE_PASSWORD }} run: pnpm build:gui - name: test build tauri for Linux if: matrix.platform.name == 'linux+x86-64' # TODO: https://tauri.app/v1/guides/distribution/sign-linux run: pnpm build:gui # - name: Codesign package # if: matrix.platform.name == 'darwin+x86-64' || matrix.platform.name == 'darwin+aarch64' # env: # APPLE_SIGNING_IDENTITY: ${{ secrets.APPLE_SIGNING_IDENTITY }} # run: | # codesign -s "Developer ID Application: Tea Inc. (7WV56FL599)" -v --force --deep --timestamp --preserve-metadata=entitlements -o runtime ./modules/gui/src-tauri/target/release/bundle/macos/tea.app || true # codesign -s "Developer ID Application: Tea Inc. (7WV56FL599)" -v --force --deep --timestamp --preserve-metadata=entitlements -o runtime ./modules/gui/src-tauri/target/release/bundle/dmg/tea_0.1.0_aarch64.dmg || true # - name: clean package for preview # if: matrix.platform.name == 'darwin+aarch64' # run: | # xattr -d com.apple.quarantine ./modules/gui/src-tauri/target/release/bundle/dmg/tea_0.1.0_aarch64.dmg # xattr -d com.apple.quarantine ./modules/gui/src-tauri/target/release/bundle/macos/tea.app - name: zip app if: matrix.platform.name == 'darwin+aarch64' 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/gui_$platform.$extension" - name: cp package zip if: matrix.platform.name == 'darwin+aarch64' env: prefix: ${{ needs.changes.outputs.preview_folder }} run: | aws s3 cp ./modules/gui/src-tauri/target/release/bundle/macos/tea.zip "s3://preview.gui.tea.xyz/$prefix/tea_m1.zip" # - name: Delete keychain # if: matrix.platform.name == 'darwin+x86-64' || matrix.platform.name == 'darwin+aarch64' # run: security delete-keychain signing_temp.keychain - name: comment install uses: mshick/add-pr-comment@v2 with: message-id: ${{ matrix.platform.name }}-comment message: | **installer for ${{ matrix.platform.name }} is at**: [here](http://preview.gui.tea.xyz.s3-website-us-east-1.amazonaws.com/${{ needs.changes.outputs.preview_folder }}/gui_${{steps.build_platform.outputs.build_platform}}.${{steps.build_platform.outputs.extension}}) ```bash http://preview.gui.tea.xyz.s3-website-us-east-1.amazonaws.com/${{ needs.changes.outputs.preview_folder }}/gui_${{ steps.build_platform.outputs.build_platform }}.${{ steps.build_platform.outputs.extension }} ``` copy-paste into a browser to download