mirror of
https://github.com/GeWuYou/GFramework.git
synced 2026-05-07 00:39:00 +08:00
- 修复 git-cliff 模板重复输出提交的问题 - 更新 GitHub Release 使用 release notes 文件作为正文 - 补充 PR review 修复记录与验证结果
4.5 KiB
4.5 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 -> patch、BREAKING CHANGE或! -> major - 为手动
workflow_dispatch保留 dry-run 验证入口,先验证最近提交会算出什么版本
当前恢复点
- 恢复点编号:
SEMREL-RP-004 - 当前阶段:
Phase 2 - 当前焦点:
- 收敛 PR #312 最新 AI review 的 release notes 输出问题
- 确保
.github/cliff.toml不再重复输出同一批 commits - 确保
publish.yml创建 GitHub Release 时通过文件传递多行 release notes
已知风险
GITHUB_TOKEN推送 tag 不会再触发另一个 workflow,真实发布仍需要PAT_TOKENsemantic-releasepreview 虽然不会真实推送 tag,但仍会执行远端git push --dry-run权限探测;如果 PAT 仅具备 read 权限、没有contents:write,仍然会先于版本分析阶段失败semantic-release的版本判断完全依赖 Conventional Commits;不规范提交会直接影响版本计算cycjimmy/semantic-release-action@v6需要在 preview / release 两端都安装conventional-changelog-conventionalcommits以保证conventionalcommitspreset 在 GitHub Actions 中可解析- 当前仓库本地
dotnet clean/build会带出既有 analyzer warnings;本轮仅修正发版配置与文档,不额外处理这些历史 warning 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清理,避免异常退出时遗留临时文件路径干扰日志 - 已同步更新 active trace 到
SEMREL-RP-004,记录本轮 PR review 收敛结果 - 已用
$gframework-pr-review抓取 PR #312 最新 review payload,确认未失败测试、未发现 MegaLinter 明细,仍有 CodeRabbit / Greptile 针对 release notes 的未解决线程 - 已移除
.github/cliff.toml中## What's Changed下的未分组 commit 循环,仅保留按 Conventional Commit group 分类后的输出,避免每个 commit 在生成的 changelog 中出现两次 - 已将
.github/workflows/publish.yml的 GitHub Release 正文从多行 expression 改为body_path: RELEASE_NOTES.md, 复用git-cliff-action写出的 release notes 文件
验证
python3 -c 'import tomllib; tomllib.load(open(".github/cliff.toml", "rb")); print("cliff.toml OK")'- 结果:通过
- 备注:确认
.github/cliff.toml仍为合法 TOML
python3 -c 'import yaml; yaml.safe_load(open(".github/workflows/publish.yml", encoding="utf-8")); print("publish.yml OK")'- 结果:通过
- 备注:确认
.github/workflows/publish.yml仍可解析为 YAML
yq '.jobs."create-release".steps[] | select(.name == "Create GitHub Release and Upload Assets") | .with' .github/workflows/publish.yml- 结果:通过
- 备注:确认 release step 现在使用
body_path: RELEASE_NOTES.md
dotnet build GFramework.sln -c Release- 结果:通过
- 备注:Release 构建通过,
0 warning / 0 error;本轮只改动 GitHub Actions / git-cliff 配置
- 更早阶段的 dry-run / tag /抽象项目验证已归档到
ai-plan/public/semantic-release-versioning/archive/todos/semantic-release-versioning-2026-04-26.md
下一步
- 提交并推送本轮 PR review 修复
- 重新抓取 PR review,确认 CodeRabbit / Greptile 的 release notes open threads 已转为过时或可关闭
- 如 CI 仍报告 release notes 发布问题,再优先复查
git-cliff-action输出文件路径与action-gh-release输入契约