ci: simplify CI matrix and more comprehensive tests #1943
Workflow file for this run
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: 'ci' | |
on: | |
push: | |
branches: | |
- '**' | |
- '!renovate/**' | |
paths-ignore: | |
- README.md | |
- CONTRIBUTING.md | |
pull_request: | |
branches: | |
- '**' | |
jobs: | |
build: | |
runs-on: ubuntu-latest | |
name: Build the package | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: pnpm/action-setup@v3 | |
- uses: actions/setup-node@v4 | |
with: | |
node-version: 22 | |
cache: 'pnpm' | |
- run: pnpm install | |
env: | |
CYPRESS_INSTALL_BINARY: 0 | |
CHROMEDRIVER_SKIP_DOWNLOAD: true | |
- run: pnpm build | |
- run: pnpm test:unit | |
# Use cache to share the output across different jobs | |
# No need to cache node_modules because they are all bundled | |
- uses: actions/cache/save@v4 | |
id: cache | |
with: | |
path: outfile.cjs | |
key: ${{ github.sha }}-${{ hashFiles('pnpm-lock.yaml') }} | |
test-build: | |
needs: build | |
strategy: | |
matrix: | |
node-version: [22] | |
os: [ubuntu-latest, windows-latest, macos-latest] | |
runs-on: ${{ matrix.os }} | |
continue-on-error: ${{ matrix.os == 'windows-latest' }} | |
env: | |
# Sometimes the Linux runner can't verify Cypress in 30s | |
CYPRESS_VERIFY_TIMEOUT: 60000 | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: pnpm/action-setup@v3 | |
- uses: actions/setup-node@v4 | |
with: | |
node-version: ${{ matrix.node-version }} | |
cache: 'pnpm' | |
- uses: actions/cache/restore@v4 | |
id: cache-restore | |
with: | |
path: | | |
outfile.cjs | |
playground | |
key: ${{ github.sha }}-${{ hashFiles('pnpm-lock.yaml') }} | |
- name: Build the package on cache miss | |
if: steps.cache-restore.outputs.cache-hit != 'true' | |
run: pnpm install && pnpm build && pnpm snapshot && cd playground && pnpm install --no-frozen-lockfile | |
- name: Run build script in playground | |
working-directory: ./playground | |
run: pnpm --filter "*" build | |
test-vitest: | |
needs: build | |
strategy: | |
matrix: | |
node-version: [22] | |
os: [ubuntu-latest, windows-latest, macos-latest] | |
runs-on: ${{ matrix.os }} | |
continue-on-error: ${{ matrix.os == 'windows-latest' }} | |
env: | |
CYPRESS_INSTALL_BINARY: 0 | |
CHROMEDRIVER_SKIP_DOWNLOAD: true | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: pnpm/action-setup@v3 | |
- uses: actions/setup-node@v4 | |
with: | |
node-version: ${{ matrix.node-version }} | |
cache: 'pnpm' | |
- uses: actions/cache/restore@v4 | |
id: cache-restore | |
with: | |
path: | | |
outfile.cjs | |
playground | |
key: ${{ github.sha }}-${{ hashFiles('pnpm-lock.yaml') }} | |
- name: Build the package on cache miss | |
if: steps.cache-restore.outputs.cache-hit != 'true' | |
run: pnpm install && pnpm build && pnpm snapshot && cd playground && pnpm install --no-frozen-lockfile | |
- name: Run test:unit script in vitest projects | |
working-directory: ./playground | |
run: pnpm --filter "{*vitest*}" test:unit | |
# FIXME: it's failing now | |
# - name: Run test:unit script in with-tests projects | |
# working-directory: ./playground | |
# run: pnpm --filter "{*with-tests*}" test:unit | |
test-e2e: | |
needs: build | |
strategy: | |
matrix: | |
e2e-framework: ['cypress', 'playwright'] | |
node-version: [22] | |
os: [ubuntu-latest, windows-latest, macos-latest] | |
runs-on: ${{ matrix.os }} | |
continue-on-error: ${{ matrix.os == 'windows-latest' }} | |
env: | |
# Sometimes the Linux runner can't verify Cypress in 30s | |
CYPRESS_VERIFY_TIMEOUT: 60000 | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: pnpm/action-setup@v3 | |
- uses: actions/setup-node@v4 | |
with: | |
node-version: ${{ matrix.node-version }} | |
cache: 'pnpm' | |
- uses: actions/cache/restore@v4 | |
id: cache-restore | |
with: | |
path: | | |
outfile.cjs | |
playground | |
key: ${{ github.sha }}-${{ hashFiles('pnpm-lock.yaml') }} | |
- name: Build the package on cache miss | |
if: steps.cache-restore.outputs.cache-hit != 'true' | |
run: pnpm install && pnpm build && pnpm snapshot && cd playground && pnpm install --no-frozen-lockfile | |
# https://github.com/vitejs/vite/blob/main/.github/workflows/ci.yml#L62 | |
# Install playwright's binary under custom directory to cache | |
- name: Set Playwright & Cypress path | |
run: | | |
echo "PLAYWRIGHT_BROWSERS_PATH=$HOME/.cache/playwright-bin" >> $GITHUB_ENV | |
echo "CYPRESS_CACHE_FOLDER=$HOME/.cache/cypress-bin" >> $GITHUB_ENV | |
- name: Set Playwright & Cypress path (windows) | |
if: runner.os == 'Windows' | |
run: | | |
echo "PLAYWRIGHT_BROWSERS_PATH=$HOME\.cache\playwright-bin" >> $env:GITHUB_ENV | |
echo "CYPRESS_CACHE_FOLDER=$HOME\.cache\cypress-bin" >> $env:GITHUB_ENV | |
- if: ${{ contains(matrix.e2e-framework, 'cypress') }} | |
name: Cache Cypress binaries | |
id: cache-cypress | |
uses: actions/cache@v4 | |
with: | |
# TODO: avoid snowballing by adding version | |
key: ${{ runner.os }}-cypress-bin | |
path: ${{ env.CYPRESS_CACHE_FOLDER }} | |
- if: ${{ contains(matrix.e2e-framework, 'playwright') }} | |
name: Cache Playwright's binary | |
uses: actions/cache@v4 | |
with: | |
# Playwright removes unused browsers automatically | |
# So does not need to add playwright version to key | |
key: ${{ runner.os }}-playwright-bin-v1 | |
path: ${{ env.PLAYWRIGHT_BROWSERS_PATH }} | |
- name: Download Cypress | |
if: ${{ contains(matrix.e2e-framework, 'cypress') }} | |
working-directory: ./playground/cypress | |
run: | | |
pnpm exec cypress cache list | |
pnpm exec cypress install | |
- if: ${{ contains(matrix.e2e-framework, 'playwright') }} | |
name: Install Playwright dependencies | |
working-directory: ./playground/playwright | |
run: npx playwright install --with-deps | |
# Run `test:e2e` in project folders contain `matrix.e2e-framework` | |
- name: Run e2e test script | |
working-directory: ./playground | |
run: pnpm --filter "{*${{ matrix.e2e-framework }}*}" test:e2e | |
# FIXME: `--with-tests` folders | |
# FIXME: Cypress component testing for projects without Vitest | |
# FIXME: test-lint | |
# `pnpm lint --no-fix --max-warnings=0` |