mirror of
https://github.com/ankitects/anki.git
synced 2026-06-11 00:49:47 -04:00
## Linked issue Closes #4863 ## Summary / motivation Adds Playwright as the e2e test framework so contributors can write browser-based tests against a real headless Anki instance. There was no automated way to exercise mediasrv pages, SvelteKit routes, or the `/_anki/` RPC surface from a browser, this PR establishes that harness. Key pieces: - `qt/tests/launch_anki_for_e2e.py` — spawns a throwaway Anki instance (temp `ANKI_BASE`, `QT_QPA_PLATFORM=offscreen`). Pre-seeds `prefs21.db` so Anki skips the language picker and profile chooser and goes straight to serving mediasrv. - `playwright.config.ts` — points `webServer` at the launcher; polls `/favicon.ico` as the readiness probe. - `ts/tests/e2e/` — `fixtures.ts` base and a sanity spec that verifies mediasrv is reachable and a SvelteKit page hydrates. - `justfile` — `just test-e2e` recipe; Chromium installed to `out/playwright-browsers/`. - CI — e2e step in `check-linux`; failed-run artifacts uploaded for 7 days. - `docs/e2e-testing.md` — contributor guide covering setup, managed vs reuse-server modes, and writing new tests. ## How to test Build the project once, then run the e2e suite in managed mode (no separate `./run` needed — the launcher is started automatically): ```shell just build just test-e2e ``` ## Before / after behavior (optional) Before: no browser-level test harness existed. After: `just test-e2e` drives a real headless Anki instance via Playwright. ## Risk / compatibility / migration No production code changed. New dev-only files and CI step only. Chromium is installed to `out/playwright-browsers/` (gitignored) and does not affect the regular build. --------- Co-authored-by: Abdo <abdo@abdnh.net>
95 lines
2.9 KiB
Markdown
95 lines
2.9 KiB
Markdown
# End-to-End Testing with Playwright
|
|
|
|
Playwright drives a real headless Anki instance via its mediasrv HTTP API.
|
|
Tests live in `ts/tests/e2e/` and are entirely separate from the Vitest unit tests.
|
|
|
|
## Prerequisites
|
|
|
|
Build Anki at least once before running e2e tests:
|
|
|
|
```shell
|
|
just build
|
|
```
|
|
|
|
That's it. `just test-e2e` automatically installs Playwright's Chromium browser
|
|
into `out/playwright-browsers/` on the first run (idempotent on subsequent runs).
|
|
|
|
## Running tests
|
|
|
|
### Managed mode (CI-style)
|
|
|
|
Playwright starts and stops a throwaway Anki instance automatically:
|
|
|
|
```shell
|
|
just test-e2e
|
|
```
|
|
|
|
The first run can be slow (~60 s) because Anki must fully initialise before tests start.
|
|
|
|
### Reuse-server mode (recommended for development)
|
|
|
|
Start Anki once in a separate terminal, then reuse it across multiple test runs:
|
|
|
|
```shell
|
|
# Terminal 1 — keep running
|
|
./run
|
|
|
|
# Terminal 2 — fast iteration
|
|
ANKI_E2E_REUSE_SERVER=1 just test-e2e
|
|
```
|
|
|
|
### Interactive UI mode
|
|
|
|
Open Playwright's browser UI to inspect each test step with snapshots:
|
|
|
|
```shell
|
|
ANKI_E2E_REUSE_SERVER=1 just test-e2e --ui
|
|
```
|
|
|
|
## Writing tests
|
|
|
|
Add test files to `ts/tests/e2e/` with the `.test.ts` suffix and import from
|
|
`./fixtures` instead of directly from `@playwright/test`:
|
|
|
|
```typescript
|
|
import { expect, test } from "./fixtures";
|
|
|
|
test("my feature works", async ({ page }) => {
|
|
await page.goto("/some-anki-page");
|
|
await expect(page.locator("#some-element")).toBeVisible();
|
|
});
|
|
```
|
|
|
|
`fixtures.ts` re-exports `expect` and a pre-configured `test` object. Add
|
|
shared fixtures there as new features require them.
|
|
|
|
## Calling the Anki API from tests
|
|
|
|
Anki's `/_anki/` endpoints accept and return protobuf-encoded binary payloads
|
|
(`Content-Type: application/binary`). Use `page.request.post` with
|
|
`Buffer.from(protoMsg.toBinary())` and decode the response with the matching
|
|
generated type from `ts/lib/generated/`.
|
|
|
|
## Accessing Anki pages
|
|
|
|
Anki's mediasrv serves the following page families over HTTP:
|
|
|
|
| URL pattern | Description |
|
|
| ---------------------------- | ----------------------------- |
|
|
| `/graphs` | Statistics graphs (SvelteKit) |
|
|
| `/deck-options/[deckId]` | Deck options (SvelteKit) |
|
|
| `/congrats` | Post-study screen (SvelteKit) |
|
|
| `/card-info/[cardId]` | Card info (SvelteKit) |
|
|
| `/_anki/pages/congrats.html` | Legacy congrats page |
|
|
| `/favicon.ico` | Mediasrv liveness probe |
|
|
|
|
The add-card editor (`/editor/?mode=add`) requires a dedicated HTTP endpoint
|
|
that is not yet present in upstream Anki. It will be available once the
|
|
editor-as-web-page work (issue #3830) is merged.
|
|
|
|
## CI
|
|
|
|
The e2e tests run as part of the `check-linux` job in `.github/workflows/ci.yml`,
|
|
after the regular build and test steps. Screenshots and traces from failed runs
|
|
are uploaded as artifacts and kept for 7 days.
|