测试
OpenClaw 拥有三个 Vitest 套件(单元/集成、e2e、live)和少量的 Docker 运行器。
本文档是一份“我们如何进行测试”的指南:
- 每个套件涵盖的内容(以及它故意不涵盖的内容)
- 针对常见工作流程(本地、推送前、调试)运行哪些命令
- Live 测试如何发现凭证并选择模型/提供商
- 如何为现实世界中的模型/提供商问题添加回归测试
大多数时候:
- 全量门禁(预期推送前):
pnpm build && pnpm check && pnpm test
当你接触测试代码或需要额外的信心时:
- 覆盖率门禁:
pnpm test:coverage - E2E 套件:
pnpm test:e2e
调试真实提供商/模型时(需要真实凭证):
- Live 套件(模型 + 网关工具/镜像探测):
pnpm test:live
提示:当你只需要一个失败的测试用例时,优先通过下文描述的 allowlist 环境变量来缩小 live 测试范围。
测试套件(在哪里运行什么)
Section titled “测试套件(在哪里运行什么)”可以将这些套件视为“真实性递增”(同时不稳定性/成本也递增):
单元 / 集成(默认)
Section titled “单元 / 集成(默认)”- 命令:
pnpm test - 配置:
vitest.config.ts - 文件:
src/**/*.test.ts - 范围:
- 纯单元测试
- 进程内集成测试(网关认证、路由、工具、解析、配置)
- 针对已知 Bug 的确定性回归测试
- 预期:
- 在 CI 中运行
- 不需要真实的 Key
- 应该快速且稳定
E2E(网关冒烟测试)
Section titled “E2E(网关冒烟测试)”- 命令:
pnpm test:e2e - 配置:
vitest.e2e.config.ts - 文件:
src/**/*.e2e.test.ts - 范围:
- 多实例网关端到端行为
- WebSocket/HTTP 接口、节点配对以及更重的网络负载
- 预期:
- 在 CI 中运行(在管道中启用时)
- 不需要真实的 Key
- 比单元测试有更多的变动部分(可能会更慢)
Live(真实提供商 + 真实模型)
Section titled “Live(真实提供商 + 真实模型)”- 命令:
pnpm test:live - 配置:
vitest.live.config.ts - 文件:
src/**/*.live.test.ts - 默认:由
pnpm test:live启用(设置OPENCLAW_LIVE_TEST=1) - 范围:
- “该提供商/模型在今天使用真实凭证是否真的有效?”
- 捕获提供商格式变更、工具调用怪癖、认证问题以及速率限制行为
- 预期:
- 设计上不具备 CI 稳定性(真实网络、真实提供商策略、配额、中断)
- 花费金钱 / 使用速率限制
- 优先运行缩小的子集而不是“所有内容”
- Live 运行将 source
~/.profile以获取缺失的 API 密钥 - Anthropic 密钥轮换:设置
OPENCLAW_LIVE_ANTHROPIC_KEYS="sk-...,sk-..."(或OPENCLAW_LIVE_ANTHROPIC_KEY=sk-...)或多个ANTHROPIC_API_KEY*变量;测试将在达到速率限制时重试
我应该运行哪个套件?
Section titled “我应该运行哪个套件?”使用此决策表:
- 编辑逻辑/测试:运行
pnpm test(如果你改动很大,还要运行pnpm test:coverage) - 涉及网关网络 / WS 协议 / 配对:添加
pnpm test:e2e - 调试“我的 Bot 挂了” / 特定提供商故障 / 工具调用:运行缩小的
pnpm test:live
Live:模型冒烟测试(配置文件密钥)
Section titled “Live:模型冒烟测试(配置文件密钥)”Live 测试分为两层,以便我们可以隔离故障:
- “Direct 模型” 告诉我们提供商/模型是否能使用给定的密钥进行响应。
- “Gateway(网关) smoke” 告诉我们完整的网关+代理管道对该模型(会话、历史记录、工具、沙箱策略等)有效。
Layer 1: Direct 模型 completion (no gateway)
Section titled “Layer 1: Direct 模型 completion (no gateway)”- Test:
src/agents/models.profiles.live.test.ts - Goal:
- 枚举已发现的模型
- 使用
getApiKeyForModel来选择你有凭证的模型 - 对每个模型运行一个小规模的补全(并在需要时运行针对性的回归测试)
- How to enable:
pnpm test:live(orOPENCLAW_LIVE_TEST=1if invoking Vitest directly)
- 设置
OPENCLAW_LIVE_MODELS=modern(orall, alias for modern) 以实际运行此测试套件;否则它会跳过,以保持pnpm test:live专注于 gateway smoke - How to select models:
OPENCLAW_LIVE_MODELS=modern运行现代允许列表(Opus/Sonnet/Haiku 4.5、GPT-5.x + Codex、Gemini 3、GLM 4.7、MiniMax M2.1、Grok 4)OPENCLAW_LIVE_MODELS=all是现代化允许列表的别名- 或
OPENCLAW_LIVE_MODELS="openai/gpt-5.2,anthropic/claude-opus-4-5,..."(comma allowlist)
- How to select providers:
OPENCLAW_LIVE_PROVIDERS="google,google-antigravity,google-gemini-cli"(comma allowlist)
- Where keys come from:
- By default: profile store and env fallbacks
- 设置
OPENCLAW_LIVE_REQUIRE_PROFILE_KEYS=1以强制仅使用 profile store
- Why this exists:
- 将“提供商 API 已损坏 / 密钥无效”与“gateway agent 管道已损坏”区分开来
- 包含小型、孤立的回归测试(示例:OpenAI Responses/Codex Responses 推理重放 + 工具调用流程)
Layer 2: Gateway(网关) + dev agent smoke(“@openclaw”实际执行的操作)
Section titled “Layer 2: Gateway(网关) + dev agent smoke(“@openclaw”实际执行的操作)”- Test:
src/gateway/gateway-models.profiles.live.test.ts - Goal:
- 启动一个进程内 gateway
- 创建/修补
agent:dev:*会话(每次运行覆盖模型) - 迭代带密钥的模型并断言:
- “有意义”的响应(无工具)
- 真实的工具调用有效(读取探针)
- 可选的额外工具探针(exec+read 探针)
- OpenAI 回归路径(仅工具调用 → 后续跟进)保持正常工作
- Probe details (so you can explain failures quickly):
read探测:测试在工作区中写入一个 nonce 文件,并要求代理read它并将 nonce 回显回来。exec+read探测:测试要求代理exec-写一个 nonce 到临时文件,然后read它回来。- 图像探测:测试附加一个生成的 PNG(cat + 随机代码)并期望模型返回
cat <CODE>。 - 实现参考:
src/gateway/gateway-models.profiles.live.test.ts和src/gateway/live-image-probe.ts。
- 如何启用:
pnpm test:live(如果直接调用 Vitest,则为OPENCLAW_LIVE_TEST=1)
- 如何选择模型:
- 默认:现代允许列表(Opus/Sonnet/Haiku 4.5、GPT-5.x + Codex、Gemini 3、GLM 4.7、MiniMax M2.1、Grok 4)
OPENCLAW_LIVE_GATEWAY_MODELS=all是现代允许列表的别名- 或者设置
OPENCLAW_LIVE_GATEWAY_MODELS="provider/model"(或逗号列表)以缩小范围
- 如何选择提供商(避免“全用 OpenRouter”):
OPENCLAW_LIVE_GATEWAY_PROVIDERS="google,google-antigravity,google-gemini-cli,openai,anthropic,zai,minimax"(逗号允许列表)
- 工具和图像探测在此实时测试中始终开启:
read探测 +exec+read探测(工具压力测试)- 当模型声明支持图像输入时,运行图像探测
- 流程(高层级):
- 测试生成一个带有“CAT”+ 随机代码的微型 PNG(
src/gateway/live-image-probe.ts) - 通过
agentattachments: [{ mimeType: "image/png", content: "<base64>" }]发送 - Gateway(网关) 将附件解析为
images[](src/gateway/server-methods/agent.ts+src/gateway/chat-attachments.ts) - 嵌入式代理向模型转发多模态用户消息
- 断言:回复包含
cat+ 代码(OCR 容差:允许小错误)
- 测试生成一个带有“CAT”+ 随机代码的微型 PNG(
提示:要查看您可以在机器上测试的内容(以及确切的 provider/model ID),请运行:
openclaw models listopenclaw models list --jsonLive:Anthropic setup-token 冒烟测试
Section titled “Live:Anthropic setup-token 冒烟测试”- 测试:
src/agents/anthropic.setup-token.live.test.ts - 目标:验证 Claude Code CLI setup-token(或粘贴的 setup-token 配置文件)能否完成 Anthropic 提示词。
- 启用:
pnpm test:live(如果直接调用 Vitest,则使用OPENCLAW_LIVE_TEST=1)OPENCLAW_LIVE_SETUP_TOKEN=1
- 令牌来源(选择其一):
- 配置文件:
OPENCLAW_LIVE_SETUP_TOKEN_PROFILE=anthropic:setup-token-test - 原始令牌:
OPENCLAW_LIVE_SETUP_TOKEN_VALUE=sk-ant-oat01-...
- 配置文件:
- 模型覆盖(可选):
OPENCLAW_LIVE_SETUP_TOKEN_MODEL=anthropic/claude-opus-4-5
设置示例:
openclaw models auth paste-token --provider anthropic --profile-id anthropic:setup-token-testOPENCLAW_LIVE_SETUP_TOKEN=1 OPENCLAW_LIVE_SETUP_TOKEN_PROFILE=anthropic:setup-token-test pnpm test:live src/agents/anthropic.setup-token.live.test.tsLive:CLI 后端冒烟测试(Claude Code CLI 或其他本地 CLIs)
Section titled “Live:CLI 后端冒烟测试(Claude Code CLI 或其他本地 CLIs)”- 测试:
src/gateway/gateway-cli-backend.live.test.ts - 目标:使用本地 Gateway(网关) 后端验证 CLI + 代理管道,而不触及你的默认配置。
- 启用:
pnpm test:live(如果直接调用 Vitest,则使用OPENCLAW_LIVE_TEST=1)OPENCLAW_LIVE_CLI_BACKEND=1
- 默认值:
- 模型:
claude-cli/claude-sonnet-4-5 - 命令:
claude - 参数:
["-p","--output-format","json","--dangerously-skip-permissions"]
- 模型:
- 覆盖(可选):
OPENCLAW_LIVE_CLI_BACKEND_MODEL="claude-cli/claude-opus-4-5"OPENCLAW_LIVE_CLI_BACKEND_MODEL="codex-cli/gpt-5.2-codex"OPENCLAW_LIVE_CLI_BACKEND_COMMAND="/full/path/to/claude"OPENCLAW_LIVE_CLI_BACKEND_ARGS='["-p","--output-format","json","--permission-mode","bypassPermissions"]'OPENCLAW_LIVE_CLI_BACKEND_CLEAR_ENV='["ANTHROPIC_API_KEY","ANTHROPIC_API_KEY_OLD"]'OPENCLAW_LIVE_CLI_BACKEND_IMAGE_PROBE=1以发送真实的图片附件(路径会被注入到提示中)。OPENCLAW_LIVE_CLI_BACKEND_IMAGE_ARG="--image"以将图像文件路径作为 CLI 参数传递,而不是通过提示词注入。OPENCLAW_LIVE_CLI_BACKEND_IMAGE_MODE="repeat"(或"list")用于在设置了IMAGE_ARG时控制图片参数的传递方式。OPENCLAW_LIVE_CLI_BACKEND_RESUME_PROBE=1以发送第二轮对话并验证恢复流程。
OPENCLAW_LIVE_CLI_BACKEND_DISABLE_MCP_CONFIG=0以保持 CLI MCP 配置启用(默认通过临时空文件禁用 MCP 配置)。
示例:
OPENCLAW_LIVE_CLI_BACKEND=1 \ OPENCLAW_LIVE_CLI_BACKEND_MODEL="claude-cli/claude-sonnet-4-5" \ pnpm test:live src/gateway/gateway-cli-backend.live.test.ts推荐的实时测试方案
Section titled “推荐的实时测试方案”狭窄、明确的允许列表是最快且最稳定的:
-
单一模型,直接(无网关):
OPENCLAW_LIVE_MODELS="openai/gpt-5.2" pnpm test:live src/agents/models.profiles.live.test.ts
-
单一模型,网关冒烟测试:
OPENCLAW_LIVE_GATEWAY_MODELS="openai/gpt-5.2" pnpm test:live src/gateway/gateway-models.profiles.live.test.ts
-
跨多个提供商的工具调用:
OPENCLAW_LIVE_GATEWAY_MODELS="openai/gpt-5.2,anthropic/claude-opus-4-5,google/gemini-3-flash-preview,zai/glm-4.7,minimax/minimax-m2.1" pnpm test:live src/gateway/gateway-models.profiles.live.test.ts
-
Google 重点关注(Gemini API 密钥 + Antigravity):
- Gemini (API 密钥):
OPENCLAW_LIVE_GATEWAY_MODELS="google/gemini-3-flash-preview" pnpm test:live src/gateway/gateway-models.profiles.live.test.ts - Antigravity (OAuth):
OPENCLAW_LIVE_GATEWAY_MODELS="google-antigravity/claude-opus-4-5-thinking,google-antigravity/gemini-3-pro-high" pnpm test:live src/gateway/gateway-models.profiles.live.test.ts
- Gemini (API 密钥):
注意:
google/...使用 Gemini API (API 密钥)。google-antigravity/...使用 Antigravity OAuth 桥接器 (Cloud Code Assist 风格的代理端点)。google-gemini-cli/...使用您机器上的本地 Gemini CLI (单独的认证 + 工具怪癖)。- Gemini API 与 Gemini CLI:
- API: OpenClaw 通过 HTTP 调用 Google 托管的 Gemini API (API 密钥 / 配置文件认证); 这是大多数用户所说的 “Gemini” 的意思。
- CLI: OpenClaw 调用本地
gemini二进制文件;它有自己的认证方式,并且可能表现不同 (流式传输/工具支持/版本偏差)。
实时:模型矩阵 (我们覆盖的内容)
Section titled “实时:模型矩阵 (我们覆盖的内容)”没有固定的 “CI 模型列表” (实时测试是可选的),但以下是建议在开发机器上使用密钥定期覆盖的推荐模型。
现代冒烟测试集 (工具调用 + 图像)
Section titled “现代冒烟测试集 (工具调用 + 图像)”这是我们期望保持工作的“常见模型”运行:
- OpenAI (非 Codex):
openai/gpt-5.2(可选:openai/gpt-5.1) - OpenAI Codex:
openai-codex/gpt-5.2(可选:openai-codex/gpt-5.2-codex) - Anthropic:
anthropic/claude-opus-4-5(或anthropic/claude-sonnet-4-5) - Google (Gemini API):
google/gemini-3-pro-preview和google/gemini-3-flash-preview(避免使用较旧的 Gemini 2.x 模型) - Google (Antigravity):
google-antigravity/claude-opus-4-5-thinking和google-antigravity/gemini-3-flash - Z.AI (GLM):
zai/glm-4.7 - MiniMax:
minimax/minimax-m2.1
运行包含工具 + 图像的网关冒烟测试:
OPENCLAW_LIVE_GATEWAY_MODELS="openai/gpt-5.2,openai-codex/gpt-5.2,anthropic/claude-opus-4-5,google/gemini-3-pro-preview,google/gemini-3-flash-preview,google-antigravity/claude-opus-4-5-thinking,google-antigravity/gemini-3-flash,zai/glm-4.7,minimax/minimax-m2.1" pnpm test:live src/gateway/gateway-models.profiles.live.test.ts
基准:工具调用 (Read + 可选 Exec)
Section titled “基准:工具调用 (Read + 可选 Exec)”每个提供商系列至少选择一个:
- OpenAI:
openai/gpt-5.2(或openai/gpt-5-mini) - Anthropic:
anthropic/claude-opus-4-5(或anthropic/claude-sonnet-4-5) - Google:
google/gemini-3-flash-preview(或google/gemini-3-pro-preview) - Z.AI (GLM):
zai/glm-4.7 - MiniMax:
minimax/minimax-m2.1
可选的额外覆盖(最好有):
- xAI:
xai/grok-4(或最新可用版本) - Mistral:
mistral/… (选择一个你已启用的支持“工具”的模型) - Cerebras:
cerebras/… (如果你有访问权限) - LM Studio:
lmstudio/… (本地;工具调用取决于 API 模式)
Vision: 图片发送(附件 → 多模态消息)
Section titled “Vision: 图片发送(附件 → 多模态消息)”在 OPENCLAW_LIVE_GATEWAY_MODELS 中至少包含一个支持图像的模型(Claude/Gemini/OpenAI 支持视觉的变体等),以测试图像探测。
聚合器 / 备用网关
Section titled “聚合器 / 备用网关”如果你启用了密钥,我们还支持通过以下方式进行测试:
- OpenRouter:
openrouter/...(数百个模型;使用openclaw models scan查找支持工具和图像的候选者) - OpenCode Zen:
opencode/...(通过OPENCODE_API_KEY/OPENCODE_ZEN_API_KEY进行身份验证)
更多你可以包含在实时矩阵中的提供商(如果你有凭据/配置):
- 内置:
openai、openai-codex、anthropic、google、google-vertex、google-antigravity、google-gemini-cli、zai、openrouter、opencode、xai、groq、cerebras、mistral、github-copilot - 通过
models.providers(自定义端点):minimax(云/API),以及任何 OpenAI/Anthropic 兼容的代理(LM Studio、vLLM、LiteLLM 等)
提示:不要试图在文档中硬编码“所有模型”。权威列表取决于 discoverModels(...) 在你的机器上返回的内容 + 可用的密钥。
凭据(切勿提交)
Section titled “凭据(切勿提交)”实时测试发现凭据的方式与 CLI 相同。实际影响如下:
-
如果 CLI 能正常工作,实时测试应该能找到相同的密钥。
-
如果实时测试提示“no creds”(无凭据),请按照调试
openclaw models list/ 模型选择的方式进行调试。 -
配置文件存储:
~/.openclaw/credentials/(首选;即测试中“profile keys”的含义) -
配置:
~/.openclaw/openclaw.json(或OPENCLAW_CONFIG_PATH)
如果你希望依赖环境变量密钥(例如在你的 ~/.profile 中导出的),请在 source ~/.profile 之后运行本地测试,或者使用下方的 Docker 运行器(它们可以将 ~/.profile 挂载到容器中)。
Deepgram 实时(音频转录)
Section titled “Deepgram 实时(音频转录)”- 测试:
src/media-understanding/providers/deepgram/audio.live.test.ts - 启用:
DEEPGRAM_API_KEY=... DEEPGRAM_LIVE_TEST=1 pnpm test:live src/media-understanding/providers/deepgram/audio.live.test.ts
Docker 运行器(可选的“在 Linux 上工作”检查)
Section titled “Docker 运行器(可选的“在 Linux 上工作”检查)”这些运行器在仓库 Docker 镜像内运行 pnpm test:live,挂载你的本地配置目录和工作区(如果已挂载,还会加载 ~/.profile):
- 直接模型:
pnpm test:docker:live-models(脚本:scripts/test-live-models-docker.sh) - Gateway(网关) 网关 + 开发代理:
pnpm test:docker:live-gateway(脚本:scripts/test-live-gateway-models-docker.sh) - 新手引导向导(TTY,完整脚手架):
pnpm test:docker:onboard(脚本:scripts/e2e/onboard-docker.sh) - Gateway(网关) 网络(两个容器,WS 认证 + 健康检查):
pnpm test:docker:gateway-network(脚本:scripts/e2e/gateway-network-docker.sh) - 插件(自定义扩展加载 + 注册中心冒烟测试):
pnpm test:docker:plugins(脚本:scripts/e2e/plugins-docker.sh)
有用的环境变量:
OPENCLAW_CONFIG_DIR=...(默认:~/.openclaw)挂载到/home/node/.openclawOPENCLAW_WORKSPACE_DIR=...(默认:~/.openclaw/workspace)挂载到/home/node/.openclaw/workspaceOPENCLAW_PROFILE_FILE=...(默认:~/.profile)挂载到/home/node/.profile并在运行测试前加载OPENCLAW_LIVE_GATEWAY_MODELS=.../OPENCLAW_LIVE_MODELS=...用于缩小运行范围OPENCLAW_LIVE_REQUIRE_PROFILE_KEYS=1以确保凭据来自配置文件存储(而非环境变量)
文档健全性检查
Section titled “文档健全性检查”在编辑文档后运行文档检查:pnpm docs:list。
离线回归(CI 安全)
Section titled “离线回归(CI 安全)”这些是不包含真实提供商的“真实管道”回归测试:
- Gateway(网关) 网关工具调用(模拟 OpenAI,真实的 Gateway(网关) 网关 + 代理循环):
src/gateway/gateway.tool-calling.mock-openai.test.ts - Gateway(网关) 向导 (WS
wizard.start/wizard.next, 写入配置 + 强制执行身份验证):src/gateway/gateway.wizard.e2e.test.ts
Agent 代理可靠性评估
Section titled “Agent 代理可靠性评估”我们已经有一些行为类似于“Agent 代理可靠性评估”的 CI 安全测试:
- 通过真实的 Gateway 网关 + 代理循环模拟工具调用(
src/gateway/gateway.tool-calling.mock-openai.test.ts)。 - 验证会话连接和配置效果的端到端向导流程(
src/gateway/gateway.wizard.e2e.test.ts)。
Skills 方面仍缺失的内容(请参阅 Skills):
- 决策制定:当提示词中列出了 Skills 时,Agent 代理是否会选择正确的 Skill(或避开不相关的 Skill)?
- 合规性:Agent 代理在使用前是否会阅读
SKILL.md并遵循所需的步骤/参数? - 工作流契约:断言工具顺序、会话历史记录继承以及沙箱边界的多轮场景。
未来的评估应首先保持确定性:
- 使用模拟提供商来断言工具调用 + 顺序、Skill 文件读取以及会话连接的场景运行程序。
- 一套专注于 Skills 的小型场景(使用与避免、选通、提示词注入)。
- 只有在 CI 安全测试套件就绪后,才进行可选的实时评估(需选择加入、由环境变量控制)。
添加回归测试(指导原则)
Section titled “添加回归测试(指导原则)”当您修复在实时测试中发现的提供商/模型问题时:
- 如果可能,添加 CI 安全的回归测试(模拟/存根提供商,或捕获精确的请求形状转换)
- 如果它本质上仅限实时测试(速率限制、身份验证策略),请保持实时测试的狭窄性,并通过环境变量选择加入
- 优先定位捕获 Bug 的最小层级:
- 提供商请求转换/重放 Bug → 直接模型测试
- gateway 会话/history/工具 pipeline bug → gateway live smoke or CI-safe gateway mock test