Skip to content

Bump the effect group across 1 directory with 3 updates #906

Bump the effect group across 1 directory with 3 updates

Bump the effect group across 1 directory with 3 updates #906

Workflow file for this run

name: CI
on:
push:
branches:
- 'main'
pull_request:
schedule:
- cron: '0 0 * * *'
permissions:
contents: read
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: ${{ github.ref != 'refs/heads/main' }}
env:
OBSERVABLE_TELEMETRY_DISABLE: 1
jobs:
build-dist:
name: 'Build dist'
runs-on: ubuntu-22.04
timeout-minutes: 30
steps:
- name: 'Checkout code'
uses: actions/[email protected]
- name: 'Set up Node.js'
uses: actions/[email protected]
with:
node-version-file: package.json
cache: ${{ !env.ACT && 'npm' || '' }}
- name: 'Find current date'
id: date
run: echo "date=$(date +'%Y-%m-%d')" >> $GITHUB_OUTPUT
- name: 'Setup data cache'
uses: actions/[email protected]
with:
path: src/.observablehq/cache
key: data-${{ hashFiles('src/data/*') }}-${{ steps.date.outputs.date }}
- name: 'Install dependencies'
run: npm ci --engine-strict
- name: 'Build dist'
run: npx observable build
env:
PREREVIEW_REVIEWS_DATA_TOKEN: ${{ secrets.PREREVIEW_REVIEWS_DATA_TOKEN }}
FATHOM_TOKEN: ${{ secrets.FATHOM_TOKEN }}
SANDBOX: ${{ github.ref != 'refs/heads/main' }}
- name: 'Upload build'
uses: actions/[email protected]
with:
name: dist
path: dist/
build-image:
name: 'Build image'
runs-on: ubuntu-22.04
timeout-minutes: 30
outputs:
image: ${{ steps.build.outputs.imageid }}
needs:
- build-dist
steps:
- name: 'Checkout code'
uses: actions/[email protected]
- name: 'Set up Docker Build'
uses: docker/[email protected]
- name: 'Download dist'
uses: actions/[email protected]
with:
name: dist
path: dist/
- name: 'Build image'
id: build
uses: docker/[email protected]
with:
context: .
outputs: type=docker,dest=/tmp/image.tar
cache-from: type=gha,ignore-error=true
cache-to: type=gha,mode=max,ignore-error=true
target: prod
- name: 'Upload build'
uses: actions/[email protected]
with:
name: image
path: /tmp/image.tar
format:
name: 'Format'
runs-on: ubuntu-22.04
timeout-minutes: 30
if: github.event_name != 'schedule'
steps:
- name: 'Checkout code'
uses: actions/[email protected]
- name: 'Set up Node.js'
uses: actions/[email protected]
with:
node-version-file: package.json
cache: ${{ !env.ACT && 'npm' || '' }}
- name: 'Install dependencies'
run: npm ci --engine-strict
- name: 'Run formatter'
run: npx prettier --ignore-unknown --check '**'
lint:
name: 'Lint'
runs-on: ubuntu-22.04
timeout-minutes: 30
if: github.event_name != 'schedule'
steps:
- name: 'Checkout code'
uses: actions/[email protected]
- name: 'Set up Node.js'
uses: actions/[email protected]
with:
node-version-file: package.json
cache: ${{ !env.ACT && 'npm' || '' }}
- name: 'Install dependencies'
run: npm ci --engine-strict
- name: 'Run the linter'
run: npx eslint . --max-warnings 0
test:
name: 'Test'
runs-on: ubuntu-22.04
timeout-minutes: 30
if: github.event_name != 'schedule'
steps:
- name: 'Checkout code'
uses: actions/[email protected]
- name: 'Set up Node.js'
uses: actions/[email protected]
with:
node-version-file: package.json
cache: ${{ !env.ACT && 'npm' || '' }}
- name: 'Install dependencies'
run: npm ci --engine-strict
- name: 'Run the tests'
run: npx vitest run
test-integration:
name: 'Integration test'
runs-on: ubuntu-22.04
timeout-minutes: 30
if: github.event_name != 'schedule'
needs:
- build-dist
steps:
- name: 'Checkout code'
uses: actions/[email protected]
- name: 'Set up Node.js'
uses: actions/[email protected]
with:
node-version-file: package.json
cache: ${{ !env.ACT && 'npm' || '' }}
- name: 'Install dependencies'
run: npm ci --engine-strict
- name: 'Download dist'
uses: actions/[email protected]
with:
name: dist
path: dist/
- name: 'Run Playwright'
id: 'playwright'
uses: docker://mcr.microsoft.com/playwright:v1.49.1-jammy
with:
args: env HOME=/root npx playwright test --forbid-only
- name: 'Store results'
if: failure() && steps.playwright.outcome == 'failure'
uses: actions/[email protected]
with:
name: integration-tests-result
path: integration-results
typecheck:
name: 'Typecheck'
runs-on: ubuntu-22.04
timeout-minutes: 30
if: github.event_name != 'schedule'
steps:
- name: 'Checkout code'
uses: actions/[email protected]
- name: 'Set up Node.js'
uses: actions/[email protected]
with:
node-version-file: package.json
cache: ${{ !env.ACT && 'npm' || '' }}
- name: 'Install dependencies'
run: npm ci --engine-strict
- name: 'Run typechecker'
run: npx tsc --noEmit
push:
name: 'Push image'
runs-on: ubuntu-22.04
timeout-minutes: 30
if: github.ref == 'refs/heads/main' && !failure() && !cancelled()
outputs:
image: ${{ steps.image.outputs.image }}
needs:
- build-image
- format
- lint
- test
- test-integration
- typecheck
steps:
- name: 'Set up flyctl'
uses: superfly/flyctl-actions/[email protected]
- name: 'Log in to the registry'
run: flyctl auth docker
env:
FLY_API_TOKEN: ${{ secrets.FLY_API_TOKEN }}
- name: 'Download image'
uses: actions/[email protected]
with:
name: image
path: /tmp
- name: 'Load image'
run: docker load --input /tmp/image.tar
- name: 'Generate image name'
id: image
run: echo "image=registry.fly.io/prereview-stats:${{ github.sha }}-${{ github.run_id }}-${{ github.run_attempt }}" >> $GITHUB_OUTPUT
- name: 'Tag image'
run: docker tag ${{ needs.build-image.outputs.image }} ${{ steps.image.outputs.image }}
- name: 'Push image'
run: docker push ${{ steps.image.outputs.image }}
deploy:
name: 'Deploy'
runs-on: ubuntu-22.04
timeout-minutes: 30
if: github.ref == 'refs/heads/main' && !failure() && !cancelled()
needs:
- push
steps:
- name: 'Checkout code'
uses: actions/[email protected]
with:
sparse-checkout: fly.toml
sparse-checkout-cone-mode: false
- name: 'Set up flyctl'
uses: superfly/flyctl-actions/[email protected]
- name: 'Deploy app'
run: flyctl deploy --image ${{ needs.push.outputs.image }}
env:
FLY_API_TOKEN: ${{ secrets.FLY_API_TOKEN }}
notify:
name: 'Notify of failure'
runs-on: ubuntu-22.04
timeout-minutes: 30
needs:
- deploy
if: failure() && github.ref == 'refs/heads/main'
steps:
- uses: voxmedia/[email protected]
env:
SLACK_BOT_TOKEN: ${{ secrets.SLACK_NOTIFICATIONS_BOT_TOKEN }}
with:
channel_id: G015ZLXJA9W
status: FAILED
color: danger