Test
- Kit pengujian lengkap (suite, live, Docker): Testing
-
pnpm test:force: Menghentikan proses gateway yang masih tersisa yang menahan port kontrol default, lalu menjalankan suite Vitest penuh dengan port gateway terisolasi agar test server tidak bertabrakan dengan instance yang sedang berjalan. Gunakan ini saat eksekusi gateway sebelumnya meninggalkan port 18789 dalam keadaan terpakai. -
pnpm test:coverage: Menjalankan suite unit dengan cakupan V8 (melaluivitest.unit.config.ts). Threshold global adalah 70% untuk lines/branches/functions/statements. Cakupan mengecualikan entrypoint yang berat di integrasi (wiring CLI, bridge gateway/telegram, server statis webchat) agar target tetap fokus pada logika yang bisa diuji unit. -
pnpm test:coverage:changed: Menjalankan cakupan unit hanya untuk file yang berubah sejakorigin/main. -
pnpm test:changed: menjalankan config proyek Vitest native dengan--changed origin/main. Config dasar memperlakukan file proyek/config sebagaiforceRerunTriggersagar perubahan wiring tetap memicu rerun luas saat diperlukan. -
pnpm test: menjalankan config root projects Vitest native secara langsung. Filter file bekerja secara native di seluruh proyek yang dikonfigurasi. -
Config dasar Vitest sekarang default ke
pool: "threads"danisolate: false, dengan runner non-isolated bersama diaktifkan di seluruh config repo. -
pnpm test:channelsmenjalankanvitest.channels.config.ts. -
pnpm test:extensionsmenjalankanvitest.extensions.config.ts. -
pnpm test:extensions: menjalankan suite extension/plugin. -
pnpm test:perf:imports: mengaktifkan pelaporan durasi import + rincian import Vitest untuk eksekusi root projects native. -
pnpm test:perf:imports:changed: profiling import yang sama, tetapi hanya untuk file yang berubah sejakorigin/main. -
pnpm test:perf:profile:main: menulis profil CPU untuk thread utama Vitest (.artifacts/vitest-main-profile). -
pnpm test:perf:profile:runner: menulis profil CPU + heap untuk unit runner (.artifacts/vitest-runner-profile). -
Integrasi gateway: opt-in melalui
OPENCLAW_TEST_INCLUDE_GATEWAY=1 pnpm testataupnpm test:gateway. -
pnpm test:e2e: Menjalankan test smoke end-to-end gateway (pairing multi-instance WS/HTTP/node). Default kethreads+isolate: falsedengan worker adaptif divitest.e2e.config.ts; sesuaikan denganOPENCLAW_E2E_WORKERS=<n>dan setelOPENCLAW_E2E_VERBOSE=1untuk log verbose. -
pnpm test:live: Menjalankan test live provider (minimax/zai). Memerlukan API key danLIVE=1(atau*_LIVE_TEST=1khusus provider) agar tidak di-skip. -
pnpm test:docker:openwebui: Memulai OpenClaw + Open WebUI dalam Docker, login melalui Open WebUI, memeriksa/api/models, lalu menjalankan chat proksi nyata melalui/api/chat/completions. Memerlukan model key live yang dapat digunakan (misalnya OpenAI di~/.profile), menarik image Open WebUI eksternal, dan tidak diharapkan stabil di CI seperti suite unit/e2e normal. -
pnpm test:docker:mcp-channels: Memulai container Gateway yang sudah diseed dan container klien kedua yang menjalankanopenclaw mcp serve, lalu memverifikasi penemuan percakapan terarah, pembacaan transkrip, metadata lampiran, perilaku antrean event live, routing pengiriman keluar, serta notifikasi channel + izin gaya Claude melalui bridge stdio yang nyata. Asersi notifikasi Claude membaca frame MCP stdio mentah secara langsung agar smoke mencerminkan apa yang benar-benar dipancarkan bridge.
Gate PR lokal
Untuk pemeriksaan land/gate PR lokal, jalankan:pnpm checkpnpm buildpnpm testpnpm check:docs
pnpm test flake pada host yang sibuk, jalankan ulang sekali sebelum menganggapnya regresi, lalu isolasi dengan pnpm test <path/to/test>. Untuk host dengan memori terbatas, gunakan:
OPENCLAW_VITEST_MAX_WORKERS=1 pnpm testOPENCLAW_VITEST_FS_MODULE_CACHE_PATH=/tmp/openclaw-vitest-cache pnpm test:changed
Benchmark latensi model (key lokal)
Skrip:scripts/bench-model.ts
Penggunaan:
source ~/.profile && pnpm tsx scripts/bench-model.ts --runs 10- Env opsional:
MINIMAX_API_KEY,MINIMAX_BASE_URL,MINIMAX_MODEL,ANTHROPIC_API_KEY - Prompt default: “Balas dengan satu kata: ok. Tanpa tanda baca atau teks tambahan.”
- minimax median 1279ms (min 1114, maks 2431)
- opus median 2454ms (min 1224, maks 3170)
Benchmark startup CLI
Skrip:scripts/bench-cli-startup.ts
Penggunaan:
pnpm test:startup:benchpnpm test:startup:bench:smokepnpm test:startup:bench:savepnpm test:startup:bench:updatepnpm test:startup:bench:checkpnpm tsx scripts/bench-cli-startup.tspnpm tsx scripts/bench-cli-startup.ts --runs 12pnpm tsx scripts/bench-cli-startup.ts --preset realpnpm tsx scripts/bench-cli-startup.ts --preset real --case status --case gatewayStatus --runs 3pnpm tsx scripts/bench-cli-startup.ts --entry openclaw.mjs --entry-secondary dist/entry.js --preset allpnpm tsx scripts/bench-cli-startup.ts --preset all --output .artifacts/cli-startup-bench-all.jsonpnpm tsx scripts/bench-cli-startup.ts --preset real --case gatewayStatusJson --output .artifacts/cli-startup-bench-smoke.jsonpnpm tsx scripts/bench-cli-startup.ts --preset real --cpu-prof-dir .artifacts/cli-cpupnpm tsx scripts/bench-cli-startup.ts --json
startup:--version,--help,health,health --json,status --json,statusreal:health,status,status --json,sessions,sessions --json,agents list --json,gateway status,gateway status --json,gateway health --json,config get gateway.portall: kedua preset
sampleCount, avg, p50, p95, min/max, distribusi exit-code/signal, dan ringkasan RSS maksimum untuk setiap perintah. --cpu-prof-dir / --heap-prof-dir opsional menulis profil V8 per run sehingga pencatatan waktu dan pengambilan profil menggunakan harness yang sama.
Konvensi output tersimpan:
pnpm test:startup:bench:smokemenulis artefak smoke yang ditargetkan ke.artifacts/cli-startup-bench-smoke.jsonpnpm test:startup:bench:savemenulis artefak suite penuh ke.artifacts/cli-startup-bench-all.jsonmenggunakanruns=5danwarmup=1pnpm test:startup:bench:updatemenyegarkan fixture baseline yang di-check-in ditest/fixtures/cli-startup-bench.jsonmenggunakanruns=5danwarmup=1
test/fixtures/cli-startup-bench.json- Segarkan dengan
pnpm test:startup:bench:update - Bandingkan hasil saat ini terhadap fixture dengan
pnpm test:startup:bench:check
Onboarding E2E (Docker)
Docker bersifat opsional; ini hanya diperlukan untuk test smoke onboarding dalam container. Alur cold-start penuh di container Linux yang bersih:openclaw health.
Smoke impor QR (Docker)
Memastikanqrcode-terminal dimuat di runtime Node Docker yang didukung (Node 24 default, Node 22 kompatibel):