feat: add headless replay support for recorded Playwright tests
- add replay target to Makefile - introduce scripts/replay.sh for headless test execution - document replay workflow in README - clarify requirements and Arch Linux setup https://chatgpt.com/share/6984a4ca-1118-800f-88f9-1bd0146e922d
This commit is contained in:
6
Makefile
6
Makefile
@@ -19,3 +19,9 @@ install:
|
||||
## 🎥 Run Playwright Codegen (GUI recording)
|
||||
codegen:
|
||||
bash scripts/codegen.sh
|
||||
|
||||
.PHONY: replay
|
||||
|
||||
## ▶ Replay recorded Playwright tests (headless)
|
||||
replay:
|
||||
bash scripts/replay.sh
|
||||
|
||||
30
README.md
30
README.md
@@ -37,12 +37,18 @@ Perfect for:
|
||||
|
||||
### 1️⃣ Requirements
|
||||
|
||||
* Docker
|
||||
* X11 or XWayland (Wayland-only will NOT work)
|
||||
* `xhost`
|
||||
- Docker
|
||||
- X11 or XWayland (Wayland-only will NOT work)
|
||||
- `xhost`
|
||||
|
||||
On Arch Linux:
|
||||
|
||||
```bash
|
||||
sudo pacman -S --needed xorg-xhost
|
||||
```
|
||||
|
||||
---
|
||||
|
||||
## ⚙️ Installation (one-time)
|
||||
|
||||
Prepare the recorder script:
|
||||
@@ -69,6 +75,24 @@ Or with a start URL:
|
||||
|
||||
---
|
||||
|
||||
## ▶ Replay recorded tests (headless)
|
||||
|
||||
Run all recorded tests:
|
||||
|
||||
```bash
|
||||
make replay
|
||||
```
|
||||
|
||||
Run a specific test file:
|
||||
|
||||
```bash
|
||||
./scripts/replay.sh recordings/login.spec.ts
|
||||
```
|
||||
|
||||
Replay runs **headless**, without X11, and does **not** require `xhost`.
|
||||
|
||||
---
|
||||
|
||||
## 📤 Output
|
||||
|
||||
* 📄 Generated test:
|
||||
|
||||
106
scripts/replay.sh
Normal file
106
scripts/replay.sh
Normal file
@@ -0,0 +1,106 @@
|
||||
#!/usr/bin/env bash
|
||||
set -euo pipefail
|
||||
|
||||
# -----------------------------------------------------------------------------
|
||||
# playwright-recorder: Replay Playwright tests (headless)
|
||||
#
|
||||
# Purpose:
|
||||
# - Replay previously generated Playwright tests
|
||||
# - Run fully headless
|
||||
# - Use Docker + official Playwright image
|
||||
# - No GUI, no X11, no xhost
|
||||
#
|
||||
# Usage:
|
||||
# ./scripts/replay.sh
|
||||
# ./scripts/replay.sh recordings/login.spec.ts
|
||||
#
|
||||
# Optional env vars:
|
||||
# PLAYWRIGHT_VERSION=1.58.1
|
||||
# PLAYWRIGHT_IMAGE=mcr.microsoft.com/playwright:v1.58.1-jammy
|
||||
# RECORDINGS_DIR=recordings
|
||||
# -----------------------------------------------------------------------------
|
||||
|
||||
PLAYWRIGHT_VERSION="${PLAYWRIGHT_VERSION:-1.58.1}"
|
||||
PLAYWRIGHT_IMAGE="${PLAYWRIGHT_IMAGE:-mcr.microsoft.com/playwright:v${PLAYWRIGHT_VERSION}-jammy}"
|
||||
|
||||
RECORDINGS_DIR="${RECORDINGS_DIR:-recordings}"
|
||||
TEST_FILE="${1:-}"
|
||||
|
||||
die() { echo "ERROR: $*" >&2; exit 1; }
|
||||
|
||||
require_cmd() {
|
||||
command -v "$1" >/dev/null 2>&1 || die "Missing command: $1"
|
||||
}
|
||||
|
||||
repo_root() {
|
||||
git rev-parse --show-toplevel 2>/dev/null || pwd
|
||||
}
|
||||
|
||||
require_cmd docker
|
||||
|
||||
ROOT="$(repo_root)"
|
||||
REC_DIR="${ROOT}/${RECORDINGS_DIR}"
|
||||
|
||||
[[ -d "${REC_DIR}" ]] || die "Recordings dir not found: ${REC_DIR}"
|
||||
|
||||
# Build ephemeral workspace
|
||||
WORK_DIR="${REC_DIR}/.replay-work"
|
||||
|
||||
rm -rf "${WORK_DIR}"
|
||||
mkdir -p "${WORK_DIR}/tests"
|
||||
|
||||
cleanup() {
|
||||
rm -rf "${WORK_DIR}" >/dev/null 2>&1 || true
|
||||
}
|
||||
trap cleanup EXIT
|
||||
|
||||
# Copy recorded tests into workspace
|
||||
if [[ -n "${TEST_FILE}" ]]; then
|
||||
[[ -f "${ROOT}/${TEST_FILE}" ]] || die "Test file not found: ${TEST_FILE}"
|
||||
cp "${ROOT}/${TEST_FILE}" "${WORK_DIR}/tests/"
|
||||
else
|
||||
shopt -s nullglob
|
||||
cp "${REC_DIR}"/*.spec.ts "${WORK_DIR}/tests/" || die "No *.spec.ts found in ${REC_DIR}"
|
||||
fi
|
||||
|
||||
# Minimal Playwright project
|
||||
cat > "${WORK_DIR}/package.json" <<EOF
|
||||
{
|
||||
"name": "playwright-replay",
|
||||
"private": true,
|
||||
"type": "commonjs",
|
||||
"devDependencies": {
|
||||
"@playwright/test": "${PLAYWRIGHT_VERSION}"
|
||||
},
|
||||
"scripts": {
|
||||
"test": "playwright test"
|
||||
}
|
||||
}
|
||||
EOF
|
||||
|
||||
cat > "${WORK_DIR}/playwright.config.ts" <<'EOF'
|
||||
import { defineConfig } from '@playwright/test';
|
||||
|
||||
export default defineConfig({
|
||||
testDir: './tests',
|
||||
use: {
|
||||
headless: true,
|
||||
trace: 'retain-on-failure',
|
||||
},
|
||||
});
|
||||
EOF
|
||||
|
||||
echo "▶ Replaying Playwright tests"
|
||||
echo "Image : ${PLAYWRIGHT_IMAGE}"
|
||||
echo "Workspace : ${WORK_DIR}"
|
||||
echo "Tests : ${TEST_FILE:-all recordings}"
|
||||
echo
|
||||
|
||||
docker run --rm \
|
||||
-v "${WORK_DIR}:/work" \
|
||||
-w /work \
|
||||
"${PLAYWRIGHT_IMAGE}" \
|
||||
bash -lc "npm install --no-audit --no-fund && npx playwright test"
|
||||
|
||||
echo
|
||||
echo "✔ Replay finished"
|
||||
Reference in New Issue
Block a user