Dogfood: minimal Vite + Playwright fixture for discover-tests #69
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| name: CI | |
| on: | |
| push: | |
| branches: [main] | |
| pull_request: | |
| branches: [main] | |
| concurrency: | |
| group: ci-${{ github.ref }} | |
| cancel-in-progress: true | |
| jobs: | |
| lint: | |
| runs-on: ubuntu-latest | |
| steps: | |
| - uses: actions/checkout@v6 | |
| - uses: actions/setup-python@v6 | |
| with: | |
| python-version: "3.12" | |
| - run: pip install ruff | |
| - run: ruff check src/ tests/ | |
| unit: | |
| runs-on: ubuntu-latest | |
| env: | |
| # Repository secret (Settings → Secrets → Actions). Empty for PRs from forks without secrets. | |
| OPENAI_API_KEY: ${{ secrets.OPENAI_API_KEY }} | |
| # Import ``docgen`` from the PR checkout, not only the copy under site-packages (avoids stale VHS fixes). | |
| PYTHONPATH: ${{ github.workspace }}/src | |
| strategy: | |
| matrix: | |
| python-version: ["3.10", "3.11", "3.12"] | |
| steps: | |
| - uses: actions/checkout@v6 | |
| - uses: actions/setup-python@v6 | |
| with: | |
| python-version: ${{ matrix.python-version }} | |
| - name: Install system dependencies | |
| run: | | |
| set -euo pipefail | |
| attempt=1 | |
| max_attempts=4 | |
| backoff=4 | |
| while [ "$attempt" -le "$max_attempts" ]; do | |
| echo "apt attempt $attempt/$max_attempts" | |
| if timeout 600s sudo apt-get -o Acquire::Retries=3 update \ | |
| && timeout 600s sudo apt-get -o Acquire::Retries=3 install -y --no-install-recommends ffmpeg tesseract-ocr xvfb ttyd; then | |
| exit 0 | |
| fi | |
| if [ "$attempt" -eq "$max_attempts" ]; then | |
| echo "apt failed after $max_attempts attempts" | |
| exit 1 | |
| fi | |
| echo "apt failed, retrying in ${backoff}s..." | |
| sleep "$backoff" | |
| backoff=$((backoff * 2)) | |
| attempt=$((attempt + 1)) | |
| done | |
| - run: pip install --no-cache-dir ".[dev]" | |
| # VHS terminal capture needs a DISPLAY (headless Ubuntu has none by default). | |
| - run: xvfb-run -a pytest tests/ --ignore=tests/e2e -v --tb=short | |
| playwright-vite-dogfood: | |
| name: Playwright Vite dogfood fixture | |
| runs-on: ubuntu-latest | |
| steps: | |
| - uses: actions/checkout@v6 | |
| - uses: actions/setup-node@v6 | |
| with: | |
| node-version: "20" | |
| cache: npm | |
| cache-dependency-path: fixtures/playwright-vite-dogfood/package-lock.json | |
| - name: Install fixture deps + Playwright (Chromium) | |
| working-directory: fixtures/playwright-vite-dogfood | |
| run: | | |
| npm ci | |
| npx playwright install --with-deps chromium | |
| - name: Run Playwright tests against Vite dev server | |
| working-directory: fixtures/playwright-vite-dogfood | |
| env: | |
| CI: "1" | |
| run: npm run test:e2e | |
| - uses: actions/setup-python@v6 | |
| with: | |
| python-version: "3.12" | |
| - name: Install docgen (CLI) | |
| run: pip install --no-cache-dir . | |
| - name: docgen discover-tests includes fixture spec | |
| env: | |
| PYTHONPATH: ${{ github.workspace }}/src | |
| run: | | |
| set -euo pipefail | |
| cd docs/demos | |
| docgen --config docgen.yaml discover-tests --format=json | python3 - <<'PY' | |
| import json, sys | |
| data = json.load(sys.stdin) | |
| assert len(data) >= 1, "expected at least one discovered Playwright test" | |
| assert any( | |
| "smoke.spec.ts" in (t.get("spec_path") or "") | |
| for t in data | |
| ), f"expected smoke.spec.ts in discovery output: {data!r}" | |
| PY | |
| smoke: | |
| name: smoke (config + lint + tts dry-run) | |
| runs-on: ubuntu-latest | |
| env: | |
| OPENAI_API_KEY: ${{ secrets.OPENAI_API_KEY }} | |
| steps: | |
| - uses: actions/checkout@v6 | |
| - uses: actions/setup-python@v6 | |
| with: | |
| python-version: "3.12" | |
| - run: pip install . | |
| - name: Validate config loads | |
| run: docgen --config docs/demos/docgen.yaml validate --help | |
| - name: Narration lint | |
| run: docgen --config docs/demos/docgen.yaml lint | |
| - name: TTS dry-run | |
| run: docgen --config docs/demos/docgen.yaml tts --dry-run | |
| e2e: | |
| runs-on: ubuntu-latest | |
| env: | |
| OPENAI_API_KEY: ${{ secrets.OPENAI_API_KEY }} | |
| PYTHONPATH: ${{ github.workspace }}/src | |
| steps: | |
| - uses: actions/checkout@v6 | |
| - uses: actions/setup-python@v6 | |
| with: | |
| python-version: "3.12" | |
| - run: pip install ".[dev]" | |
| - run: playwright install --with-deps chromium | |
| - run: pytest tests/e2e/ -v --tb=short |