2 Commits

Author SHA1 Message Date
5079e85eb5 Release version 1.1.0 2026-02-05 15:14:24 +01:00
5e9da6dc63 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
2026-02-05 15:09:55 +01:00
4 changed files with 144 additions and 3 deletions

View File

@@ -1,3 +1,8 @@
## [1.1.0] - 2026-02-05
* 🎬 Enable replay of recorded Playwright tests in headless mode
## [1.0.0] - 2026-02-05
* Official Release 🥳

View File

@@ -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

View File

@@ -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
View 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"