mirror of
https://github.com/JefferyHcool/BiliNote.git
synced 2026-05-13 08:50:32 +08:00
v2.1.3 push master 时 Lint commit messages job 红了,根因两条:
1. workflow 里写了 'firstParent: false',但 wagoid/commitlint-github-action@v6
的合法 input 列表里没这个字段,被 ignore 同时打 warn
2. release merge commit 标题 'Release v2.1.3' 不符合 type(scope): subject 格式,
commitlint 报 subject-empty + type-empty
· @commitlint/config-conventional 默认 ignore 'Merge ' 前缀的 commit,
但我们手动 -m 把标题写成 'Release vX.Y.Z' 跳过了豁免
修:
- 去掉 .github/workflows/commitlint.yml 里那条 firstParent 假 input
- RELEASING.md §3 加入 merge commit 标题模板:
· 合 master 用 'chore(release): vX.Y.Z'
· 回灌 develop 用 'chore(release): merge release/X.Y.Z back into develop'
- CONTRIBUTING.md §6.3 同步加这条提醒
历史上 master / develop 的 'Release v2.1.x' 那几个 merge commit 已经在 history
里,没法回头改(不能强推 master)。但 commitlint 在 push 时只 lint 推送范围里的
新 commit,旧 commit 不会重新校验,所以不会持续报错。
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
162 lines
5.6 KiB
Markdown
162 lines
5.6 KiB
Markdown
# 发版手册(Release Manager)
|
||
|
||
本文档面向**发版执行者**,覆盖从 `develop` 切发版到产物上架商店的完整步骤。日常分支与提交规范见 [CONTRIBUTING.md](./CONTRIBUTING.md)。
|
||
|
||
---
|
||
|
||
## 流程总览
|
||
|
||
```
|
||
develop ──→ release/X.Y.Z ──→ PR ─→ master ──→ 打 tag vX.Y.Z
|
||
│ │ │
|
||
└──→ PR 回灌 ──→ develop └──→ CI 自动构建插件产物 + 挂到 GitHub Release
|
||
↓
|
||
人工上传商店(Chrome/Edge/Firefox)
|
||
```
|
||
|
||
---
|
||
|
||
## 1. 切发布分支
|
||
|
||
```bash
|
||
git checkout develop && git pull origin develop
|
||
git checkout -b release/X.Y.Z
|
||
```
|
||
|
||
版本号遵循 [SemVer](https://semver.org/lang/zh-CN/):`MAJOR.MINOR.PATCH`。
|
||
|
||
## 2. 写 CHANGELOG,更新版本号
|
||
|
||
在 `release/X.Y.Z` 上:
|
||
|
||
- 编辑 [`CHANGELOG.md`](./CHANGELOG.md),新增 `## [X.Y.Z] - YYYY-MM-DD` 段,按 Keep a Changelog 分类(Added / Changed / Fixed / Removed / Security / Internal)
|
||
- 编辑 [`README.md`](./README.md) 顶部标题中的版本号 + 新增"vX.Y.Z 新增"摘要段
|
||
- 重大变更也同步更新 [`CLAUDE.md`](./CLAUDE.md)
|
||
|
||
```bash
|
||
git commit -am "docs: vX.Y.Z CHANGELOG + README 版本"
|
||
git push -u origin release/X.Y.Z
|
||
```
|
||
|
||
## 3. 合并到 master + 回灌 develop
|
||
|
||
在 GitHub 上发起两个 PR:
|
||
|
||
| PR | base | 合并方式 | 合并后 commit 标题 |
|
||
|---|---|---|---|
|
||
| `release/X.Y.Z` → `master` | `master` | **Merge commit (--no-ff)** | `chore(release): vX.Y.Z` |
|
||
| `release/X.Y.Z` → `develop` | `develop` | **Merge commit (--no-ff)** | `chore(release): merge release/X.Y.Z back into develop` |
|
||
|
||
> ⚠️ Merge commit 的标题**必须**符合 `type(scope): subject` 格式(commitlint 在 push 到 master/develop 时会校验)。
|
||
> 历史上用过 `Release vX.Y.Z` 这种形式,会被 commitlint 报 `type-empty` / `subject-empty`。
|
||
|
||
`master` 分支保护要求 review 通过。回灌 `develop` 是为了把发版冻结期内的小修同步回来。
|
||
|
||
## 4. 打 tag
|
||
|
||
```bash
|
||
git checkout master && git pull origin master
|
||
git tag -a vX.Y.Z -m "BiliNote vX.Y.Z
|
||
|
||
主线:
|
||
- ...
|
||
|
||
详见 CHANGELOG.md"
|
||
git push origin vX.Y.Z
|
||
```
|
||
|
||
push tag **会自动触发 [`.github/workflows/release-extension.yml`](.github/workflows/release-extension.yml)**:构建插件并把 `.zip` / `.xpi` / `.crx` 挂到对应 GitHub Release。
|
||
|
||
## 5. 创建 GitHub Release(如果还没有)
|
||
|
||
CI 默认会创建 / 更新 `vX.Y.Z` 对应的 Release。如果你想自己写 release notes:
|
||
|
||
1. 打开 https://github.com/JefferyHcool/BiliNote/releases/new
|
||
2. Tag: 选 `vX.Y.Z`
|
||
3. Title: `vX.Y.Z`
|
||
4. Body: 直接贴 [`CHANGELOG.md`](./CHANGELOG.md) 的对应段
|
||
5. CI 跑完后 Release 页面会自动出现 `bilinote-extension-X.Y.Z.zip` / `.xpi` / `.crx`
|
||
|
||
## 6. 上传到各商店(人工)
|
||
|
||
商店审核普遍 1-3 个工作日。建议**先上 Chrome → Edge → Firefox**(Edge 接受同一份 zip)。
|
||
|
||
### Chrome Web Store
|
||
|
||
1. https://chrome.google.com/webstore/devconsole
|
||
2. 选 BiliNote → 左侧 **Package** → **Upload new package**
|
||
3. 上传 `bilinote-extension-X.Y.Z.zip`
|
||
4. 检查 listing(描述 / 图标 / 截图无变化可保持),点 **Submit for review**
|
||
|
||
### Microsoft Edge Add-ons
|
||
|
||
1. https://partner.microsoft.com/dashboard/microsoftedge
|
||
2. 选 BiliNote → **New submission**
|
||
3. 上传同一份 `.zip`(Edge Add-ons 与 Chrome 完全兼容 MV3)
|
||
4. 提交审核
|
||
|
||
### Firefox Add-ons (AMO)
|
||
|
||
1. https://addons.mozilla.org/developers/
|
||
2. 选 BiliNote → **Upload New Version**
|
||
3. 上传 `bilinote-extension-X.Y.Z.xpi`
|
||
4. 选择"在 AMO 公开"或"自托管"
|
||
5. 提交审核
|
||
|
||
### 桌面端 (Tauri)
|
||
|
||
仓库已有 GitHub Actions 在 `v*` tag 时构建桌面端安装包并自动挂到 GitHub Release,无需额外操作。
|
||
|
||
## 7. 清理
|
||
|
||
```bash
|
||
# release 分支已合到 master 与 develop,删掉
|
||
git push origin --delete release/X.Y.Z
|
||
git branch -d release/X.Y.Z
|
||
```
|
||
|
||
---
|
||
|
||
## 自动发布到商店(可选)
|
||
|
||
`.github/workflows/release-extension.yml` 末尾有三段商店自动发布的 job 注释。要启用:
|
||
|
||
1. 在 https://github.com/JefferyHcool/BiliNote/settings/secrets/actions 加 secrets:
|
||
|
||
| 商店 | 需要的 secret |
|
||
|---|---|
|
||
| Chrome | `CHROME_EXTENSION_ID`、`CHROME_CLIENT_ID`、`CHROME_CLIENT_SECRET`、`CHROME_REFRESH_TOKEN` |
|
||
| Edge | `EDGE_PRODUCT_ID`、`EDGE_CLIENT_ID`、`EDGE_API_KEY` |
|
||
| Firefox | `FIREFOX_ADDON_UUID`、`FIREFOX_API_KEY`、`FIREFOX_API_SECRET` |
|
||
|
||
2. 解开 workflow 文件末尾的 `publish-chrome` / `publish-edge` / `publish-firefox` job 注释。
|
||
3. 推 tag 时即自动发布。
|
||
|
||
> Chrome 各 secret 的获取方式:[chrome-webstore-upload-cli 文档](https://github.com/fregante/chrome-webstore-upload-cli/blob/main/How%20to%20generate%20Google%20API%20keys.md)
|
||
> Edge:[Edge Add-ons API](https://learn.microsoft.com/en-us/microsoft-edge/extensions-chromium/publish/api/using-addons-api)
|
||
> Firefox:https://addons.mozilla.org/en-US/developers/addon/api/key/
|
||
|
||
---
|
||
|
||
## 紧急 hotfix 发版
|
||
|
||
线上紧急问题不走 `release/*`,走 `hotfix/*`:
|
||
|
||
```bash
|
||
git checkout master && git pull
|
||
git checkout -b hotfix/<scope>-<事项>
|
||
# … 修复 ...
|
||
# PR base=master 合入;同时 PR base=develop 回灌
|
||
```
|
||
|
||
合入 master 后通常打 patch tag(如 `v2.1.1`),CI 流程同上。
|
||
|
||
---
|
||
|
||
## 历史发布快查
|
||
|
||
| Version | Date | Tag |
|
||
|---|---|---|
|
||
| 2.1.0 | 2026-05-07 | [`v2.1.0`](https://github.com/JefferyHcool/BiliNote/releases/tag/v2.1.0) |
|
||
| 2.0.0 | (上游 web 端 v2.0.0) | [`v2.0.0`](https://github.com/JefferyHcool/BiliNote/releases/tag/v2.0.0) |
|