Refactor Fillet Playwright Test to the new Fixture-based Approach #3230
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: E2E Tests | |
on: | |
push: | |
branches: [ main ] | |
pull_request: | |
branches: [ main ] | |
concurrency: | |
group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} | |
cancel-in-progress: true | |
permissions: | |
contents: write | |
pull-requests: write | |
actions: read | |
jobs: | |
check-rust-changes: | |
runs-on: ubuntu-latest | |
outputs: | |
rust-changed: ${{ steps.filter.outputs.rust }} | |
steps: | |
- uses: actions/checkout@v4 | |
- id: filter | |
name: Check for Rust changes | |
uses: dorny/paths-filter@v3 | |
with: | |
filters: | | |
rust: | |
- 'src/wasm-lib/**' | |
electron: | |
timeout-minutes: 60 | |
name: playwright:electron:${{ matrix.os }} ${{ matrix.shardIndex }} ${{ matrix.shardTotal }} | |
strategy: | |
fail-fast: false | |
matrix: | |
# TODO: enable self-hosted-windows-8-cores once available | |
os: [namespace-profile-ubuntu-8-cores, namespace-profile-macos-8-cores, windows-16-cores] | |
shardIndex: [1, 2, 3, 4] | |
shardTotal: [4] | |
runs-on: ${{ matrix.os }} | |
needs: check-rust-changes | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: actions/setup-node@v4 | |
with: | |
node-version-file: '.nvmrc' | |
cache: 'yarn' | |
- uses: KittyCAD/action-install-cli@main | |
- name: Install dependencies | |
shell: bash | |
run: yarn | |
- name: Cache Playwright Browsers | |
uses: actions/cache@v4 | |
with: | |
path: | | |
~/.cache/ms-playwright/ | |
key: ${{ runner.os }}-playwright-${{ hashFiles('yarn.lock') }} | |
- name: Install Playwright Browsers | |
shell: bash | |
run: yarn playwright install --with-deps | |
- name: Download Wasm Cache | |
id: download-wasm | |
if: needs.check-rust-changes.outputs.rust-changed == 'false' | |
uses: dawidd6/action-download-artifact@v7 | |
continue-on-error: true | |
with: | |
github_token: ${{secrets.GITHUB_TOKEN}} | |
name: wasm-bundle | |
workflow: build-and-store-wasm.yml | |
branch: main | |
path: src/wasm-lib/pkg | |
- name: copy wasm blob | |
if: needs.check-rust-changes.outputs.rust-changed == 'false' | |
shell: bash | |
run: cp src/wasm-lib/pkg/wasm_lib_bg.wasm public | |
continue-on-error: true | |
- name: Setup Rust | |
uses: dtolnay/rust-toolchain@stable | |
- name: Cache Wasm (because rust diff) | |
if: needs.check-rust-changes.outputs.rust-changed == 'true' | |
uses: Swatinem/rust-cache@v2 | |
with: | |
workspaces: './src/wasm-lib' | |
- name: OR Cache Wasm (because wasm cache failed) | |
if: steps.download-wasm.outcome == 'failure' | |
uses: Swatinem/rust-cache@v2 | |
with: | |
workspaces: './src/wasm-lib' | |
- name: install good sed | |
if: ${{ startsWith(matrix.os, 'macos') }} | |
shell: bash | |
run: | | |
brew install gnu-sed | |
echo "/opt/homebrew/opt/gnu-sed/libexec/gnubin" >> $GITHUB_PATH | |
- name: Install vector | |
shell: bash | |
# TODO: figure out what to do with this, it's failing | |
if: false | |
run: | | |
curl --proto '=https' --tlsv1.2 -sSfL https://sh.vector.dev > /tmp/vector.sh | |
chmod +x /tmp/vector.sh | |
/tmp/vector.sh -y -no-modify-path | |
mkdir -p /tmp/vector | |
cp .github/workflows/vector.toml /tmp/vector.toml | |
sed -i "s#GITHUB_WORKFLOW#${GITHUB_WORKFLOW}#g" /tmp/vector.toml | |
sed -i "s#GITHUB_REPOSITORY#${GITHUB_REPOSITORY}#g" /tmp/vector.toml | |
sed -i "s#GITHUB_SHA#${GITHUB_SHA}#g" /tmp/vector.toml | |
sed -i "s#GITHUB_REF_NAME#${GITHUB_REF_NAME}#g" /tmp/vector.toml | |
sed -i "s#GH_ACTIONS_AXIOM_TOKEN#${{secrets.GH_ACTIONS_AXIOM_TOKEN}}#g" /tmp/vector.toml | |
cat /tmp/vector.toml | |
${HOME}/.vector/bin/vector --config /tmp/vector.toml & | |
- name: Build Wasm (because rust diff) | |
if: needs.check-rust-changes.outputs.rust-changed == 'true' | |
shell: bash | |
run: yarn build:wasm | |
- name: OR Build Wasm (because wasm cache failed) | |
if: steps.download-wasm.outcome == 'failure' | |
shell: bash | |
run: yarn build:wasm | |
- name: build electron | |
shell: bash | |
run: yarn tron:package | |
- name: Run ubuntu/chrome snapshots | |
if: ${{ matrix.os == 'namespace-profile-ubuntu-8-cores' && matrix.shardIndex == 1 }} | |
shell: bash | |
# TODO: break this in its own job, for now it's not slowing down the overall execution as ubuntu is the quickest, | |
# but we could do better. This forces a large 1/1 shard of all 20 snapshot tests that runs in about 3 minutes. | |
run: | | |
PLATFORM=web yarn playwright test --config=playwright.config.ts --retries="3" --update-snapshots --grep=@snapshot --shard=1/1 | |
env: | |
CI: true | |
NODE_ENV: development | |
VITE_KC_DEV_TOKEN: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} | |
VITE_KC_SKIP_AUTH: true | |
token: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} | |
snapshottoken: ${{ secrets.KITTYCAD_API_TOKEN }} | |
- uses: actions/upload-artifact@v4 | |
if: ${{ !cancelled() && (success() || failure()) }} | |
with: | |
name: playwright-report-${{ matrix.os }}-snapshot-${{ matrix.shardIndex }}-${{ github.sha }} | |
path: playwright-report/ | |
include-hidden-files: true | |
retention-days: 30 | |
overwrite: true | |
- name: Clean up test-results | |
if: ${{ !cancelled() && (success() || failure()) }} | |
continue-on-error: true | |
run: rm -r test-results | |
- name: check for changes | |
if: ${{ matrix.os == 'namespace-profile-ubuntu-8-cores' && matrix.shardIndex == 1 }} | |
shell: bash | |
id: git-check | |
run: | | |
git add . | |
if git status | grep -q "Changes to be committed" | |
then echo "modified=true" >> $GITHUB_OUTPUT | |
else echo "modified=false" >> $GITHUB_OUTPUT | |
fi | |
- name: Commit changes, if any | |
if: steps.git-check.outputs.modified == 'true' | |
shell: bash | |
run: | | |
git add . | |
git config --local user.email "github-actions[bot]@users.noreply.github.com" | |
git config --local user.name "github-actions[bot]" | |
git remote set-url origin https://${{ github.actor }}:${{ secrets.GITHUB_TOKEN }}@github.com/${{ github.repository }}.git | |
git fetch origin | |
echo ${{ github.head_ref }} | |
git checkout ${{ github.head_ref }} | |
git commit -am "A snapshot a day keeps the bugs away! 📷🐛 (OS: ${{matrix.os}})" || true | |
git push | |
git push origin ${{ github.head_ref }} | |
# only upload artifacts if there's actually changes | |
- uses: actions/upload-artifact@v4 | |
if: steps.git-check.outputs.modified == 'true' | |
with: | |
name: playwright-report-${{ matrix.os }}-${{ matrix.shardIndex }}-${{ github.sha }} | |
path: playwright-report/ | |
include-hidden-files: true | |
retention-days: 30 | |
- uses: actions/download-artifact@v4 | |
if: ${{ !cancelled() && (success() || failure()) }} | |
continue-on-error: true | |
with: | |
name: test-results-${{ matrix.os }}-${{ matrix.shardIndex }}-${{ github.sha }} | |
path: test-results/ | |
- name: Run playwright/electron flow (with retries) | |
id: retry | |
if: ${{ !cancelled() && (success() || failure()) }} | |
shell: bash | |
run: | | |
.github/ci-cd-scripts/playwright-electron.sh ${{matrix.shardIndex}} ${{matrix.shardTotal}} ${{matrix.os}} | |
env: | |
CI: true | |
FAIL_ON_CONSOLE_ERRORS: true | |
NODE_ENV: development | |
VITE_KC_DEV_TOKEN: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} | |
VITE_KC_SKIP_AUTH: true | |
token: ${{ secrets.KITTYCAD_API_TOKEN_DEV }} | |
- uses: actions/upload-artifact@v4 | |
if: always() | |
with: | |
name: test-results-${{ matrix.os }}-${{ matrix.shardIndex }}-${{ github.sha }} | |
path: test-results/ | |
include-hidden-files: true | |
retention-days: 30 | |
overwrite: true | |
- uses: actions/upload-artifact@v4 | |
if: always() | |
with: | |
name: playwright-report-${{ matrix.os }}-${{ matrix.shardIndex }}-${{ github.sha }} | |
path: playwright-report/ | |
include-hidden-files: true | |
retention-days: 30 | |
overwrite: true | |