Tests
- Full testing kit (suites, live, Docker): Testing
-
pnpm test:force: Kills any lingering gateway process holding the default control port, then runs the full Vitest suite with an isolated gateway port so server tests don’t collide with a running instance. Use this when a prior gateway run left port 18789 occupied. -
pnpm test:coverage: Runs the unit suite with V8 coverage (viavitest.unit.config.ts). Global thresholds are 70% lines/branches/functions/statements. Coverage excludes integration-heavy entrypoints (CLI wiring, gateway/telegram bridges, webchat static server) to keep the target focused on unit-testable logic. -
pnpm teston Node 24+: OpenClaw auto-disables VitestvmForksand usesforksto avoidERR_VM_MODULE_LINK_FAILURE/module is already linked. You can force behavior withOPENCLAW_TEST_VM_FORKS=0|1. -
pnpm test: runs the fast core unit lane by default for quick local feedback. -
pnpm test:channels: runs channel-heavy suites. -
pnpm test:extensions: runs extension/plugin suites. -
Gateway integration: opt-in via
OPENCLAW_TEST_INCLUDE_GATEWAY=1 pnpm testorpnpm test:gateway. -
pnpm test:e2e: Runs gateway end-to-end smoke tests (multi-instance WS/HTTP/node pairing). Defaults tovmForks+ adaptive workers invitest.e2e.config.ts; tune withOPENCLAW_E2E_WORKERS=<n>and setOPENCLAW_E2E_VERBOSE=1for verbose logs. -
pnpm test:live: Runs provider live tests (minimax/zai). Requires API keys andLIVE=1(or provider-specific*_LIVE_TEST=1) to unskip.
Local PR gate
For local PR land/gate checks, run:pnpm checkpnpm buildpnpm testpnpm check:docs
pnpm test flakes on a loaded host, rerun once before treating it as a regression, then isolate with pnpm vitest run <path/to/test>. For memory-constrained hosts, use:
OPENCLAW_TEST_PROFILE=low OPENCLAW_TEST_SERIAL_GATEWAY=1 pnpm test
Model latency bench (local keys)
Script:scripts/bench-model.ts
Usage:
source ~/.profile && pnpm tsx scripts/bench-model.ts --runs 10- Optional env:
MINIMAX_API_KEY,MINIMAX_BASE_URL,MINIMAX_MODEL,ANTHROPIC_API_KEY - Default prompt: “Reply with a single word: ok. No punctuation or extra text.”
- minimax median 1279ms (min 1114, max 2431)
- opus median 2454ms (min 1224, max 3170)
CLI startup bench
Script:scripts/bench-cli-startup.ts
Usage:
pnpm tsx scripts/bench-cli-startup.tspnpm tsx scripts/bench-cli-startup.ts --runs 12pnpm tsx scripts/bench-cli-startup.ts --entry dist/entry.js --timeout-ms 45000
--version--helphealth --jsonstatus --jsonstatus
Onboarding E2E (Docker)
Docker is optional; this is only needed for containerized onboarding smoke tests. Full cold-start flow in a clean Linux container:openclaw health.
QR import smoke (Docker)
Ensuresqrcode-terminal loads under Node 22+ in Docker: