这是用于更新和插件验证的专用检查清单。目标很简单:证明可安装的包能够更新真实用户状态,通过Documentation Index
Fetch the complete documentation index at: https://openclaw.zhcndoc.com/llms.txt
Use this file to discover all available pages before exploring further.
doctor 修复过时的旧状态,并且仍然可以从受支持的来源安装、加载、更新和卸载插件。
更全面的测试运行器地图请参见 Testing。关于实时 provider key 和会触发网络的套件,请参见 Testing live。
我们保护的内容
更新和插件测试保护以下契约:- 包 tarball 是完整的,具有有效的
dist/postinstall-inventory.json, 并且不依赖于解包后的仓库文件。 - 用户可以从较旧的已发布包迁移到候选包, 而不会丢失配置、agents、sessions、workspaces、插件 allowlist,或 channel 配置。
openclaw doctor --fix --non-interactive负责旧版清理和修复 路径。启动过程不应为过时的 插件状态增加隐藏的兼容性迁移。- 插件安装可从本地目录、git 仓库、npm 包以及 ClawHub registry 路径工作。
- 插件 npm 依赖会安装到受管理的 npm 根目录中,在建立信任前进行扫描, 并在卸载时通过 npm 移除,这样提升的依赖就不会 残留。
- 当没有变化时,插件更新应保持稳定:安装记录、已解析的 来源、已安装的依赖布局以及启用状态都应保持完好。
开发期间的本地验证
先从较小范围开始:release:check 会运行配置/文档/API 漂移检查,写入包 dist 清单,运行 npm pack --dry-run,拒绝被打包的禁用文件,将 tarball 安装到临时前缀,运行 postinstall,并对打包内的 channel 入口点进行冒烟测试。
Docker lanes
Docker lanes 是产品级验证。它们在 Linux 容器中安装或更新真实包,并通过 CLI 命令、Gateway 启动、HTTP 探针、RPC 状态和文件系统状态来断言行为。 迭代时使用聚焦 lanes:test:docker:plugins验证插件安装冒烟测试、本地文件夹安装、 本地文件夹更新跳过行为、带有预安装 依赖的本地文件夹、file:包安装、带 CLI 执行的 git 安装、git 移动引用更新、带有提升的传递性 依赖的 npm registry 安装、npm 更新 no-op、本地 ClawHub fixture 安装和更新 no-op、marketplace 更新行为,以及 Claude-bundle 启用/检查。设置OPENCLAW_PLUGINS_E2E_CLAWHUB=0以保持 ClawHub 模块 hermetic/离线。test:docker:plugin-lifecycle-matrix在一个裸 容器中安装候选包,对一个 npm 插件执行安装、检查、禁用、启用、 显式升级、显式降级,以及在删除插件 代码后的卸载。它会为每个阶段记录 RSS 和 CPU 指标。test:docker:plugin-update验证一个未更改的已安装插件 在openclaw plugins update期间不会重新安装,也不会丢失安装元数据。test:docker:upgrade-survivor在一个脏的 旧用户 fixture 之上安装候选 tarball,运行包更新和非交互式 doctor,然后启动 一个 loopback Gateway 并检查状态保留。test:docker:published-upgrade-survivor先安装一个已发布的基线版本, 通过内置的openclaw config set配方进行配置,将其更新到 候选 tarball,运行 doctor,检查旧版清理,启动 Gateway,并 探测/healthz、/readyz和 RPC 状态。test:docker:update-migration是以清理为重点的已发布更新 lane。它 从一个已配置的 Discord/Telegram 风格用户状态开始,运行基线 doctor,使已配置插件依赖有机会实例化,为一个已配置的打包插件 注入旧版插件依赖残留,更新到 候选 tarball,并要求更新后的 doctor 移除旧版 依赖根目录。
base、feishu-channel、bootstrap-persona,
plugin-deps-cleanup、configured-plugin-installs、tilde-log-path 和
versioned-runtime-deps。在聚合运行中,
OPENCLAW_UPGRADE_SURVIVOR_SCENARIOS=reported-issues 会展开为所有已报告的
问题形态场景,包括已配置插件安装迁移。
完整更新迁移有意与 Full Release CI 分离。当发布问题是“从 2026.4.23 起的每个
已发布稳定版本都能更新到这个候选版本并清理插件依赖残留吗?”时,请使用手动
Update Migration 工作流:
包接纳
Package Acceptance 是 GitHub 原生的包门禁。它将一个候选包解析为一个package-under-test tarball,记录版本和 SHA-256,然后针对该精确 tarball 运行可复用的 Docker E2E lanes。工作流 harness 参考与包源参考是分离的,因此当前测试逻辑可以验证较旧的受信任发布版本。
候选来源:
source=npm:验证openclaw@beta、openclaw@latest或某个精确的已发布版本。source=ref:使用所选的当前 harness 打包一个受信任的分支、tag 或 commit。source=url:验证一个带有必需package_sha256的 HTTPS tarball。source=artifact:复用另一个 Actions 运行上传的 tarball。
source=artifact,从
已解析的发布 SHA 构建。对于发布后的证明,请传入
package_acceptance_package_spec=openclaw@YYYY.M.D,这样同一套升级矩阵
就会改为针对已发布的 npm 包。
发布检查会以包/更新/插件集合调用 Package Acceptance:
all-since-2026.4.23 是 Full Release CI 的升级样本:从 2026.4.23 到 latest 的每个已通过 npm 发布的稳定版本。对于穷尽式的已发布
更新迁移覆盖,请在单独的 Update
Migration 工作流中使用 all-since-2026.4.23,而不是在 Full Release CI 中使用。release-history 仍然
可用于手动进行更广范围的采样,当你还希望包含旧的前置日期
锚点时。
在发布前验证候选版本时,手动运行一个 package profile:
suite_profile=product。仅当你需要完整的 Docker 发布路径覆盖时,才使用 suite_profile=full。
发布默认项
对于发布候选版本,默认验证栈为:pnpm check:changed和pnpm test:changed,用于源码级回归。pnpm release:check,用于包产物完整性。- Package Acceptance 的
packageprofile 或 release-check 自定义 package lanes,用于 install/update/plugin 契约。 - 跨 OS 的发布检查,用于 OS 特定安装器、引导流程和平台行为。
- 仅当变更面触及 provider 或托管服务行为时,才运行 live 套件。
旧版兼容性
兼容性宽容范围很窄且有时间限制:- 截至
2026.4.25的包,包括2026.4.25-beta.*,在 Package Acceptance 中可以容忍已发布的包元数据缺口。 - 已发布的
2026.4.26包可以对已发布的本地构建元数据 stamp 文件发出警告。 - 更晚的包必须满足现代契约。同样的缺口会失败,而不是警告或跳过。
upgrade-survivor 或 published-upgrade-survivor 证明它。
添加覆盖
当更改更新或插件行为时,请在最可能以正确原因失败的最低层添加覆盖:- 纯路径或元数据逻辑:在源代码旁添加单元测试。
- 包清单或打包文件行为:
package-dist-inventory或 tarball 检查器测试。 - CLI 安装/更新行为:Docker lane 断言或 fixture。
- 已发布版本迁移行为:
published-upgrade-survivor场景。 - registry/包来源行为:
test:docker:pluginsfixture 或 ClawHub fixture 服务器。 - 依赖布局或清理行为:同时断言运行时执行和文件系统边界。npm 依赖可能会在受管理的 npm
根目录下被提升,因此测试应证明根目录被扫描/清理,而不是假设存在
包本地的
node_modules树。
失败排查
先从产物身份开始:- Package Acceptance 的
resolve_package摘要:来源、版本、SHA-256 和产物名称。 - Docker 产物:
.artifacts/docker-tests/**/summary.json、failures.json、lane 日志和重跑命令。 - Upgrade survivor 摘要:
.artifacts/upgrade-survivor/summary.json,包括基线版本、候选版本、场景、阶段耗时和配方步骤。