mirror of
https://github.com/GeWuYou/GFramework.git
synced 2026-05-13 14:14:29 +08:00
- 修复 preview job 在 dry-run 中改用 PAT_TOKEN 并提前校验仓库访问权限 - 补充 preview summary 对远端 push 权限探测行为的说明 - 更新 semantic-release versioning 的 tracking 与 trace 恢复点和验证记录
7.3 KiB
7.3 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-003 - 当前阶段:
Phase 2 - 当前焦点:
- 消除
auto-tag.ymlpreview job 中由github-actions[bot]触发的EGITNOPERMISSION/git push --dry-run403 - 让 preview 与 release 共用同一条
PAT_TOKEN身份验证链路,避免 dry-run 与真实 release 的权限前提不一致 - 将本轮 preview 身份验证修复同步回 active trace,并等待 CI 复验结果
- 消除
已知风险
GITHUB_TOKEN推送 tag 不会再触发另一个 workflow,真实发布仍需要PAT_TOKENsemantic-releasepreview 虽然不会真实推送 tag,但仍会执行远端git push --dry-run权限探测;如果 preview 没有使用 可写入仓库的令牌,仍然会先于版本分析阶段失败semantic-release的版本判断完全依赖 Conventional Commits;不规范提交会直接影响版本计算cycjimmy/semantic-release-action@v6需要在 preview / release 两端都安装conventional-changelog-conventionalcommits以保证conventionalcommitspreset 在 GitHub Actions 中可解析- 当前仓库本地
dotnet clean/build会带出既有 analyzer warnings;本轮仅修正发版配置与文档,不额外处理这些历史 warning
已完成
- 已确认当前版本入口为
.github/workflows/auto-tag.yml,现状始终执行PATCH + 1 - 已确认当前
.github/workflows/publish.yml由 tag 触发,并负责.nupkg打包、发布和 GitHub Release - 已确认最新 tag 为
v0.0.222 - 已确认
v0.0.222..HEAD之间存在feat(...)提交,按目标规则首次 dry-run 预期版本应为v0.1.0 - 已新增
.releaserc.json,仅保留@semantic-release/commit-analyzer与@semantic-release/release-notes-generator,避免semantic-release直接创建 GitHub Release - 已将
.releaserc.json的commit-analyzer/release-notes-generator同步切换到conventionalcommitspreset,并显式声明:breaking -> majorrevert -> patchfeat -> minorfix/perf/refactor -> patchdocs/test/chore/build/ci/style -> no release
- 已将
.github/workflows/auto-tag.yml重写为:workflow_dispatch启动后总是先跑previewpreview只执行 dry-run,输出last_tag、next_version与next_tagreleasejob 依赖preview输出,并通过release-approvalenvironment 暂停等待人工确认- 人工批准后,
release在同一 SHA 上执行真实打 tag,并把 preview / release 结果都写入 job summary
- 已按 PR review 修复
auto-tag.yml:- 删除 preview job 中与 job 级
if重复的运行时分支校验 - 为 release job 增加
needs.preview.result == 'success'守卫 - 为 preview / release 的 semantic-release action 显式安装
conventional-changelog-conventionalcommits@9.1.0 - 在 release 前通过 GitHub API 校验
PAT_TOKEN是否真实可访问当前仓库 - 在 preview / release summary 中补充 snapshot 语义与生成的 release notes
- 删除 preview job 中与 job 级
- 已修复 preview 链路的鉴权前提:
- 在 preview 开始前通过 GitHub API 校验
PAT_TOKEN - 将 preview 的
semantic-release令牌从${{ github.token }}切换为${{ secrets.PAT_TOKEN }} - 在 preview summary 中明确说明 dry-run 仍会执行远端 push 权限探测,避免将 403 误判为版本计算失败
- 在 preview 开始前通过 GitHub API 校验
- 已明确真实打 tag 仍使用
PAT_TOKEN,因为GITHUB_TOKEN推送的 tag 不会继续触发publish.yml - 已更新
AGENTS.md的 Conventional Commit 规则,显式补充:fix/perf/refactor -> patchdocs/test/chore/build/ci/style -> no releaseBREAKING CHANGE或!header -> major
- 已移除基于
workflow_run和[release ci]的自动发版门闸,后续版本预览与真实发版都由维护者手动触发 - 已将 release 流程从“两次独立 workflow_dispatch”收敛为“同一次 run 里 preview + 审批 + release”的链路
- 已精简 active trace,移除已废弃的
release_mode=preview|release中间方案,保留当前有效恢复点
验证
git describe --tags --abbrev=0- 结果:通过
- 备注:当前最新 tag 为
v0.0.222
git log --pretty=format:%h%x09%s v0.0.222..HEAD- 结果:通过
- 备注:最近版本窗口内存在多条
feat(...),后续 dry-run 预期应提升minor
dotnet build GFramework.Core.Abstractions/GFramework.Core.Abstractions.csproj -c Release -p:RestoreFallbackFolders=- 结果:通过
- 备注:
GFramework.Core.Abstractions与GFramework.Cqrs.AbstractionsRelease 构建通过,0 warning / 0 error
npx --yes semantic-release --dry-run --no-ci- 结果:受阻
- 备注:当前工作树的本地 tag 历史在
git fetch --tags阶段出现would clobber existing tag冲突,不能直接作为 dry-run 环境
git clone --branch main --single-branch git@github.com:GeWuYou/GFramework.git /tmp/gframework-semrel-dryrun- 结果:通过
- 备注:已建立干净临时克隆用于 dry-run 验证
npx --yes semantic-release --dry-run --no-ci(在/tmp/gframework-semrel-dryrun)- 结果:通过
- 备注:dry-run 成功识别
v0.0.222为最新 release,并分析269个提交;按当前规则会提升到下一次minor发布,预期 tag 为v0.1.0
npx --yes -p semantic-release -p conventional-changelog-conventionalcommits@9.1.0 semantic-release --dry-run --no-ci(在/tmp/gframework-semrel-dryrun)- 结果:通过
- 备注:成功加载
@semantic-release/commit-analyzer与@semantic-release/release-notes-generator,证明conventionalcommitspreset 包可被解析;本次 dry-run 未继续出版本,是因为干净克隆的main已落后远端
dotnet build GFramework.Core.Abstractions/GFramework.Core.Abstractions.csproj -c Release -p:RestoreFallbackFolders=(手动发版入口调整后复验)- 结果:通过
- 备注:
0 warning / 0 error
dotnet build GFramework.sln -c Release- 结果:通过
- 备注:Release 构建完成,
639 warning / 0 error;warning 为仓库既有基线,与本轮 workflow / doc 改动无新增关联项
dotnet build GFramework.sln -c Release(preview 鉴权修复后复验)- 结果:通过
- 备注:Release 构建完成,
639 warning / 0 error;warning 基线与修复前一致,本轮仅涉及 workflow /ai-plan变更
下一步
- 手动重跑
Semantic Release Version and Tag的 preview job,确认不再出现git push --dry-run ... 403 - 若 preview 通过,再复核当前 PR review 的 open threads 是否只剩等待 push 的已修复项
- 将本轮修复提交到当前分支,等待 GitHub reviewer 重新评估