Skip to main content

Documentation Index

Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt

Use this file to discover all available pages before exploring further.

这是用于更新和插件验证的专用检查清单。目标很简单:证明可安装的软件包能够更新真实用户状态,通过 doctor 修复陈旧的旧版状态,并且仍然可以从受支持的来源安装、加载、更新和卸载插件。 更广泛的测试运行器映射见 测试。实时提供商密钥和会触达网络的套件见 实时测试

我们保护什么

更新和插件测试保护这些契约:
  • 软件包 tarball 是完整的,具有有效的 dist/postinstall-inventory.json,并且不依赖未打包的仓库文件。
  • 用户可以从较旧的已发布软件包迁移到候选软件包,而不会丢失配置、智能体、会话、工作区、插件 allowlist 或渠道配置。
  • openclaw doctor --fix --non-interactive 负责旧版清理和修复路径。启动过程不应为陈旧的插件状态增长隐藏的兼容性迁移。
  • 插件可从本地目录、git 仓库、npm 软件包和 ClawHub 注册表路径安装。
  • 插件 npm 依赖会安装在托管 npm 根目录中,在信任前被扫描,并在卸载期间通过 npm 移除,避免提升的依赖残留。
  • 当没有任何变更时,插件更新应保持稳定:安装记录、解析后的来源、已安装依赖布局和启用状态都保持不变。

开发期间的本地证明

从窄范围开始:
pnpm changed:lanes --json
pnpm check:changed
pnpm test:changed
对于插件安装、卸载、依赖或软件包清单变更,还要运行覆盖已编辑接缝的聚焦测试:
pnpm test src/plugins/uninstall.test.ts src/infra/package-dist-inventory.test.ts test/scripts/package-acceptance-workflow.test.ts
在任何软件包 Docker lane 使用 tarball 之前,先证明软件包构件:
pnpm release:check
release:check 会运行配置/文档/API 漂移检查,写入软件包 dist 清单,运行 npm pack --dry-run,拒绝禁止打包的文件,将 tarball 安装到临时前缀中,运行 postinstall,并对内置渠道入口点进行 smoke 测试。

Docker lanes

Docker lanes 是产品级证明。它们在 Linux 容器内安装或更新真实软件包,并通过 CLI 命令、Gateway 网关启动、HTTP 探测、RPC 状态和文件系统状态断言行为。 迭代时使用聚焦 lanes:
pnpm test:docker:plugins
pnpm test:docker:plugin-lifecycle-matrix
pnpm test:docker:plugin-update
pnpm test:docker:upgrade-survivor
pnpm test:docker:published-upgrade-survivor
pnpm test:docker:update-migration
重要 lanes:
  • test:docker:plugins 验证插件安装 smoke、本地文件夹安装、本地文件夹更新跳过行为、带预安装依赖的本地文件夹、file: 软件包安装、带 CLI 执行的 git 安装、git 移动引用更新、带提升传递依赖的 npm 注册表安装、npm 更新空操作、本地 ClawHub fixture 安装和更新空操作、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 将候选 tarball 安装到脏旧用户 fixture 上,运行软件包更新和非交互式 doctor,然后启动一个 local 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 移除旧版依赖根目录。
有用的已发布升级 survivor 变体:
OPENCLAW_UPGRADE_SURVIVOR_BASELINE_SPEC=openclaw@2026.4.23 \
OPENCLAW_UPGRADE_SURVIVOR_SCENARIO=versioned-runtime-deps \
pnpm test:docker:published-upgrade-survivor

OPENCLAW_UPGRADE_SURVIVOR_BASELINE_SPEC=openclaw@latest \
OPENCLAW_UPGRADE_SURVIVOR_SCENARIO=bootstrap-persona \
pnpm test:docker:published-upgrade-survivor
可用场景包括 basefeishu-channelbootstrap-personaplugin-deps-cleanupconfigured-plugin-installstilde-log-pathversioned-runtime-deps。在聚合运行中,OPENCLAW_UPGRADE_SURVIVOR_SCENARIOS=reported-issues 会展开为所有已报告问题形态的场景,包括已配置插件安装迁移。 完整更新迁移有意与 Full Release CI 分离。当发布问题是“从 2026.4.23 起的每个已发布稳定版本是否都能更新到此候选版本并清理插件依赖残留?”时,使用手动 Update Migration 工作流:
gh workflow run update-migration.yml \
  --ref main \
  -f workflow_ref=main \
  -f package_ref=main \
  -f baselines=all-since-2026.4.23 \
  -f scenarios=plugin-deps-cleanup

Package Acceptance

Package Acceptance 是 GitHub 原生的软件包门禁。它将一个候选软件包解析为 package-under-test tarball,记录版本和 SHA-256,然后针对这个精确 tarball 运行可复用的 Docker E2E lanes。工作流 harness ref 与软件包源 ref 分离,因此当前测试逻辑可以验证较旧的受信任发布。 候选来源:
  • source=npm:验证 openclaw@betaopenclaw@latest 或精确的已发布版本。
  • source=ref:使用所选当前 harness 打包受信任的分支、标签或提交。
  • source=url:验证需要 package_sha256 的 HTTPS tarball。
  • source=artifact:复用另一个 Actions 运行上传的 tarball。
Full Release Validation 默认使用 source=artifact,从解析后的发布 SHA 构建。对于发布后证明,传入 package_acceptance_package_spec=openclaw@YYYY.M.D,让同一个升级矩阵目标指向已发布的 npm 软件包。 发布检查会使用 package/update/plugin 集合调用 Package Acceptance:
doctor-switch update-channel-switch upgrade-survivor published-upgrade-survivor plugins-offline plugin-update
它们还会传入:
published_upgrade_survivor_baselines=all-since-2026.4.23
published_upgrade_survivor_scenarios=reported-issues
telegram_mode=mock-openai
这会让软件包迁移、更新渠道切换、陈旧插件依赖清理、离线插件覆盖、插件更新行为和 Telegram 软件包 QA 绑定到同一个解析后的构件上。 all-since-2026.4.23 是 Full Release CI 升级样本:从 2026.4.23latest 的每个稳定 npm 已发布版本。要获得详尽的已发布更新迁移覆盖,请在单独的 Update Migration 工作流中使用 all-since-2026.4.23,而不是 Full Release CI。release-history 仍可用于手动更广泛抽样,适用于你也需要旧版日期前锚点的情况。 在发布前验证候选版本时,手动运行软件包 profile:
gh workflow run package-acceptance.yml \
  --ref main \
  -f workflow_ref=main \
  -f source=npm \
  -f package_spec=openclaw@beta \
  -f suite_profile=package \
  -f published_upgrade_survivor_baselines=all-since-2026.4.23 \
  -f published_upgrade_survivor_scenarios=reported-issues \
  -f telegram_mode=mock-openai
当发布问题包含 MCP 渠道、cron/subagent 清理、OpenAI web search 或 OpenWebUI 时,使用 suite_profile=product。仅在需要完整 Docker 发布路径覆盖时使用 suite_profile=full

发布默认值

对于发布候选版本,默认证明栈是:
  1. 用于源代码级回归的 pnpm check:changedpnpm test:changed
  2. 用于软件包构件完整性的 pnpm release:check
  3. 用于安装/更新/插件契约的 Package Acceptance package profile 或 release-check 自定义软件包 lanes。
  4. 用于特定 OS 安装器、新手引导和平台行为的跨 OS 发布检查。
  5. 仅当变更面触及提供商或托管服务行为时运行实时套件。
在维护者机器上,广泛门禁和 Docker/软件包产品证明应在 Testbox 中运行,除非明确执行本地证明。

旧版兼容性

兼容性宽容范围很窄,并且有时间限制:
  • 直到 2026.4.25 的软件包,包括 2026.4.25-beta.*,可以在 Package Acceptance 中容忍已经发布的软件包元数据缺口。
  • 已发布的 2026.4.26 软件包可以对已经发布的本地构建元数据 stamp 文件发出警告。
  • 后续软件包必须满足现代契约。相同缺口会失败,而不是警告或跳过。
不要为这些旧形态添加新的启动迁移。添加或扩展 doctor 修复,然后用 upgrade-survivorpublished-upgrade-survivor 证明它。

添加覆盖

更改更新或插件行为时,在能够因正确原因失败的最低层添加覆盖:
  • 纯路径或元数据逻辑:源代码旁边的单元测试。
  • 软件包清单或打包文件行为:package-dist-inventory 或 tarball 检查器测试。
  • CLI 安装/更新行为:Docker lane 断言或 fixture。
  • 已发布版本迁移行为:published-upgrade-survivor 场景。
  • 注册表/软件包来源行为:test:docker:plugins fixture 或 ClawHub fixture server。
  • 依赖布局或清理行为:同时断言运行时执行和文件系统边界。npm 依赖可能被提升到托管 npm 根目录下,所以测试应证明根目录已被扫描/清理,而不是假设存在软件包本地 node_modules 树。
默认保持新的 Docker fixtures hermetic。除非测试重点是实时注册表行为,否则使用本地 fixture 注册表和伪软件包。

失败分诊

从构件身份开始:
  • Package Acceptance resolve_package 摘要:来源、版本、SHA-256 和构件名称。
  • Docker 构件:.artifacts/docker-tests/**/summary.jsonfailures.json、lane 日志和重新运行命令。
  • Upgrade survivor 摘要:.artifacts/upgrade-survivor/summary.json,包括基线版本、候选版本、场景、阶段耗时和配方步骤。
优先使用相同软件包构件重新运行失败的精确 lane,而不是重新运行整个发布总括流程。