Add e2e dev

This commit is contained in:
MartinBraquet
2026-02-17 15:13:16 +01:00
parent b3365cd773
commit ee1e894e2f
2 changed files with 74 additions and 0 deletions

View File

@@ -27,8 +27,10 @@
"test:watch": "yarn workspaces run test --watch",
"test:update": "yarn workspaces run test --updateSnapshot",
"test:e2e": "./scripts/e2e.sh",
"test:e2e:dev": "./scripts/e2e-dev.sh",
"test:e2e:ui": "./scripts/e2e.sh --ui",
"test:e2e:debug": "./scripts/e2e.sh --debug",
"test:e2e:services": "concurrently --names 'firebase,api,web' 'yarn emulate' 'yarn --cwd=backend/api dev' 'yarn --cwd=web dev'",
"test:db:reset": "supabase start && ./scripts/combine-migrations.sh && supabase db reset",
"test:db:reset-postgres": "docker compose -f scripts/docker-compose.test.yml down -v && docker compose -f scripts/docker-compose.test.yml up -d",
"test:db:migrate": "./scripts/test_db_migration.sh",

72
scripts/e2e-dev.sh Executable file
View File

@@ -0,0 +1,72 @@
#!/bin/bash
set -euo pipefail
cd "$(dirname "$0")"/..
# Colors
GREEN='\033[0;32m'
RED='\033[0;31m'
NC='\033[0m'
print_status() { echo -e "${GREEN}[E2E-DEV]${NC} $1"; }
print_error() { echo -e "${RED}[ERROR]${NC} $1"; }
# Check services are running (fail fast with helpful message)
check_services() {
local missing=0
if ! supabase status --output json | jq -r '.API_URL'; then
print_error "Supabase is not running. Starting..."
supabase start
supabase db reset
missing=1
fi
if ! curl -s http://127.0.0.1:9099 > /dev/null 2>&1; then
print_error "Firebase emulator is not running. Run: yarn emulate"
missing=1
fi
if ! curl -s http://localhost:8088/health > /dev/null 2>&1; then
print_error "Backend API is not running. Run: yarn --cwd=backend/api dev"
missing=1
fi
if ! curl -s http://localhost:3000 > /dev/null 2>&1; then
print_error "Next.js is not running. Run: yarn --cwd=web dev"
missing=1
fi
if [ $missing -eq 1 ]; then
echo ""
echo "Start everything with: yarn e2e:services"
echo "Or start full clean run: yarn test:e2e"
exit 1
fi
}
print_status "Checking services..."
check_services
print_status "All services running ✅"
export $(cat .env.test | grep -v '^#' | xargs)
export NEXT_PUBLIC_SUPABASE_URL=$(supabase status --output json | jq -r '.API_URL')
export NEXT_PUBLIC_SUPABASE_ANON_KEY=$(supabase status --output json | jq -r '.ANON_KEY')
export DATABASE_URL=$(supabase status --output json | jq -r '.DB_URL')
# Run tests - pass all args through to playwright
# Examples:
# yarn test:e2e:dev → all e2e tests
# yarn test:e2e:dev tests/e2e/auth.spec.ts → specific file
# yarn test:e2e:dev --grep "login" → tests matching pattern
# yarn test:e2e:dev --ui → open Playwright UI
if [ $# -eq 0 ]; then
# No arguments: run all tests in tests/e2e
print_status "Running: npx playwright test tests/e2e"
npx playwright test tests/e2e
else
# Arguments provided: pass them directly to playwright
print_status "Running: npx playwright test $@"
npx playwright test "$@"
fi