Skip to content

Playwright setup + E2E Testing #3

Playwright setup + E2E Testing

Playwright setup + E2E Testing #3

name: Run app services
on:
push:
branches: [ main, master ]
pull_request:
branches: [ main, master ]
env:
PROJECT_ID: 'benefit-decision-toolkit-play'
WORKLOAD_IDENTITY_PROVIDER: 'projects/1034049717668/locations/global/workloadIdentityPools/github-actions-google-cloud/providers/github'
jobs:
run-services:
runs-on: 'ubuntu-latest'
# Add these permissions for Workload Identity Federation
permissions:
contents: read
id-token: write
steps:
- name: Checkout repository
uses: actions/checkout@v4
# Devbox needs a .env file to exist, even if it's empty
- name: 'Create .env file'
run: touch .env
# Setup devbox which includes Node.js, Firebase CLI, and Google Cloud SDK
- name: 'Install devbox'
uses: 'jetify-com/[email protected]'
with:
enable-cache: true
# Configure Workload Identity Federation and generate an access token
- id: 'auth'
name: 'Authenticate to Google Cloud'
uses: 'google-github-actions/auth@v2'
with:
workload_identity_provider: '${{ env.WORKLOAD_IDENTITY_PROVIDER }}'
service_account: cicd-build-deploy-api@benefit-decision-toolkit-play.iam.gserviceaccount.com
project_id: ${{ env.PROJECT_ID }}
- name: Cache node modules
uses: actions/cache@v4
with:
path: builder-frontend/node_modules
key: ${{ runner.os }}-node-${{ hashFiles('builder-frontend/package-lock.json') }}
restore-keys: |
${{ runner.os }}-node-
- name: Install dependencies
working-directory: builder-frontend
run: devbox run install-builder-frontend-ci
- name: Run all services
run: devbox services up -b
continue-on-error: true
# Insert additional steps here to interact with the running services, e.g., run tests
- name: Stop all services
run: devbox services stop
continue-on-error: true