Skip to content

fix(e2e): raise live provision/claim-deploy timeout 120→180s (de-flake) #308

fix(e2e): raise live provision/claim-deploy timeout 120→180s (de-flake)

fix(e2e): raise live provision/claim-deploy timeout 120→180s (de-flake) #308

Workflow file for this run

name: Deploy to GitHub Pages
on:
push:
branches: [main]
# Run on PRs too so the `build` job reports its required status check — the
# `build` context is a required check on main, but it previously only ran on
# push, so no PR could ever satisfy it (every PR sat BLOCKED). The deploy job
# below is gated to non-PR events so PRs build but never publish to Pages.
pull_request:
branches: [main]
workflow_dispatch:
permissions:
contents: read
pages: write
id-token: write
concurrency:
# Ref-scoped so a PR build can't cancel an in-progress main Pages deploy.
group: pages-${{ github.ref }}
cancel-in-progress: true
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v6
- uses: actions/setup-node@v6
with:
node-version: '20'
cache: 'npm'
- run: npm ci
# Compute the short SHA of HEAD here so vite.config.ts can splice it
# into the bundle (define: VITE_COMMIT_ID). Mirrors what the Go services
# do via -ldflags so every frontend error reported to New Relic carries
# the same build identifier the api/worker/provisioner logs use.
- name: Export GIT_SHA
run: echo "GIT_SHA=$(git rev-parse --short HEAD)" >> "$GITHUB_ENV"
- run: npm run build
env:
VITE_API_URL: https://api.instanode.dev
# New Relic browser-agent keys. Missing or empty → main.tsx skips
# init (fail-open), so PR forks / unconfigured envs still build cleanly.
VITE_NEWRELIC_LICENSE_KEY: ${{ secrets.VITE_NEWRELIC_LICENSE_KEY }}
VITE_NEWRELIC_APP_ID: ${{ secrets.VITE_NEWRELIC_APP_ID }}
# NOTE: do NOT `cp dist/index.html dist/404.html` here. prerender.mjs
# already writes dist/404.html as the bare SPA shell so every /app/*
# bookmark / shared link / magic-link callback rehydrates the React
# router. Copying the post-prerender index.html would clobber the SPA
# shell with the homepage SSG HTML, breaking every /app/* path.
# See instanode-web/scripts/prerender.mjs Step 4.7.
- uses: actions/upload-pages-artifact@v5
with:
path: dist
deploy:
needs: build
# Publish only on push to main / manual dispatch — never on a PR.
if: github.event_name != 'pull_request'
runs-on: ubuntu-latest
environment:
name: github-pages
url: ${{ steps.deployment.outputs.page_url }}
steps:
- id: deployment
uses: actions/deploy-pages@v5