mirror of
https://github.com/GeWuYou/GFramework.git
synced 2026-05-06 16:16:44 +08:00
- 修复 release-notes-generator 的 Conventional Commits 类型映射 - 补充 SEMREL-RP-006 的验证结果与 PR review 恢复点
4.4 KiB
4.4 KiB
Semantic Release 版本迁移跟踪
目标
将版本管理从固定 patch + 1 的自动打 tag 迁移到 semantic-release,同时保留现有 .github/workflows/publish.yml
的 tag 触发打包、NuGet 发布、GitHub Packages 发布和 GitHub Release 流程。
- 用
cycjimmy/semantic-release-action替换auto-tag.yml的版本判断和打 tag 逻辑 - 保留
publish.yml的现有发布实现,不重写 NuGet 流程 - 避免
semantic-release与publish.yml重复创建 GitHub Release - 将版本规则固定为
feat -> minor、fix/perf/refactor/deps/security -> patch、BREAKING CHANGE或! -> major - 为手动
workflow_dispatch保留 dry-run 验证入口,先验证最近提交会算出什么版本
当前恢复点
- 恢复点编号:SEMREL-RP-006
- 当前阶段:处理 PR review 中的 release notes 类型映射漂移
- 当前焦点:
.releaserc.json的release-notes-generator增加presetConfig.types- 让
refactor、deps与security这类 patch 级发布原因出现在 semantic-release 生成的 notes 中 AGENTS.md和docs/zh-CN/contributing.md同步提交类型说明build/semantic-release-rules分支映射到当前 active topic
已知风险
GITHUB_TOKEN推送 tag 不会再触发另一个 workflow,真实发布仍需要PAT_TOKENsemantic-releasepreview 虽然不会真实推送 tag,但仍会执行远端git push --dry-run权限探测;如果 PAT 仅具备 read 权限、没有contents:write,仍然会先于版本分析阶段失败semantic-release的版本判断完全依赖 Conventional Commits;不规范提交会直接影响版本计算- patch 级提交类型的发布语义需要同时维护在
.releaserc.json、AGENTS.md、公开贡献文档和release-notes-generator的 notes 类型映射中,避免版本升级原因与 workflow summary 漂移 cycjimmy/semantic-release-action@v6需要在 preview / release 两端都安装conventional-changelog-conventionalcommits以保证conventionalcommitspreset 在 GitHub Actions 中可解析git-cliff-action的OUTPUT文件需要在softprops/action-gh-release执行时保留在当前工作目录,后续如调整 working-directory 或 artifact 路径,需要同步复查body_path
已完成
- 历史迁移结论与
SEMREL-RP-001到SEMREL-RP-003的稳定完成项已归档到ai-plan/public/semantic-release-versioning/archive/todos/semantic-release-versioning-2026-04-26.md - 已将 preview / release 两段重复的 PAT 校验提取到
.github/actions/validate-pat/action.yml - 已在 PAT 校验中补充
permissions.push断言,避免 read-only token 通过 API 探活却在semantic-release的git push --dry-run阶段才失败 - 已为 PAT 校验的
mktemp文件补充trap清理,避免异常退出时遗留临时文件路径干扰日志 SEMREL-RP-004的 release notes 模板修复、验证和合并后分支收尾已归档到ai-plan/public/semantic-release-versioning/archive/todos/semantic-release-versioning-rp004-2026-05-02.mdSEMREL-RP-005已扩展deps/security的 patch 发布规则,并同步提交规范文档SEMREL-RP-006已根据 PR review 复核结果补齐 release notes 类型映射,避免 patch 发布原因只触发版本而不进入 notes
验证
SEMREL-RP-004的本地验证结果已归档。SEMREL-RP-005已完成本地验证:jq . .releaserc.json通过semantic-release --dry-run --no-ci已成功加载commit-analyzer和release-notes-generator,随后因远端 tag fetch 会 clobber 本地既有 tags 而终止,未暴露配置解析错误dotnet build GFramework.sln -c Release通过,0 warning / 0 error
SEMREL-RP-006已完成本地验证:jq . .releaserc.json通过semantic-release --dry-run --no-ci已成功加载commit-analyzer和release-notes-generator,随后因远端 tag fetch 会 clobber 本地既有 tags 而终止,未暴露presetConfig.types配置解析错误dotnet build GFramework.sln -c Release通过,0 warning / 0 error
- 更早阶段的 dry-run / tag /抽象项目验证已归档到
ai-plan/public/semantic-release-versioning/archive/todos/semantic-release-versioning-2026-04-26.md
下一步
- 提交
SEMREL-RP-006的 PR review 修复 - 如后续需要完整 semantic-release 版本预览,先处理本地 tag 与远端 tag 的 clobber 冲突