- 升级 Vite+ / TypeScript / Node 版本
- 调整
vite.config.ts(根 / 各包) - 改 lint 规则(Oxlint / Oxfmt / typescript-eslint)
- 升级或替换依赖
- 修改
.vite-hooks/或 git hooks
-
package.json的engines.node与 README 的 Node.js 徽章一致 -
pnpm-lock.yaml同步生成(运行pnpm install) - 三处
tsconfig.json(根 + cli + core)的 target / module 设置一致
- 全仓跑
vp check --fix,看是否产生大量自动 reformat - 如果产生 mass diff,单独提一个 commit(代码语义改动和 lint reformat 不要混)
- 已有 warning 的处理:
- 如果新规则消除了某些旧 warning,确认是否合理
- 如果新规则产生了新 warning,评估是否要修
-
packages/cli/vite.config.ts和packages/core/vite.config.ts的 entry / external / dts 设置 - cli 的 bundle 必须把
bailian-cli-core当 external(不内联),确认dist/bailian.mjs第一行有from "bailian-cli-core" - cli 的 bundle 第一行必须有
#!/usr/bin/env nodeshebang(tools/release.mjs check会断言)
- 检查
bailian-cli-core在 cli 的dependencies里仍是"workspace:*"(不要变成实际版本号 —tools/release.mjs会拦) - 升级后跑
vp check && vp test - 升级
@types/node时注意 Node API 变化(如 fs.existsSync 行为)
-
.vite-hooks/pre-commit改动后,pnpm install重新软链(走prepare: vp config) - 增加 hook 时,确认在干净 clone 后能自动激活
-
tools/release.mjs中如有版本/规则相关的硬编码,同步更新 - 比如
secretPatterns添加新的敏感值识别
# 完整冒烟
pnpm install --frozen-lockfile
vp check
vp test
node tools/release.mjs check- ✗ 升级 Node engines 但忘了 README 徽章
- ✗ 改 lint 规则后没全仓
--fix,新人 PR 报红一片 - ✗ 改 cli 的 vite config 把 core 不小心打成 inline,bundle 体积暴涨
- ✗ Oxlint 配置改了但 IDE 缓存还是旧的(IDE 可能要重启 ts server)
- ✗ 升级依赖一并升 lockfile,改动量大但没拆 commit