Files
nofx/docs/Git工作流规范.md
Burt 91b7187e25 Git 工作流规范 (#974)
* Add files via upload

* Revise Git workflow guidelines and branch strategies

* Update git workflow

* Chores
2025-11-15 22:20:06 -05:00

13 KiB
Raw Permalink Blame History

Git 工作流规范

1. 总体目标

建立清晰、统一的 Git 工作流规范,解决团队协作中的冲突和代码丢失问题,同时有效管理开源和闭源两个版本的代码。

2. 分支管理策略

2.1 开源版本GitHub Flow

目前高频更新时期,针对开源版本的 GitHub Flow 工作流:

dev 分支
  ↓ Developer 新建功能分支
feat/hotfix 分支
  ↓ 开发、测试
  ↓ Pull Request
  ↓ Review
dev (合并回dev分支)
  ↓ 不定期完整测试
main (合并回main分支)  
  ↓ 自动发布
Release Tag

分支规范:

  • main:唯一稳定分支
  • dev:高频更新分支
  • 功能开发分支:开发者自建分支,feat/功能描述 格式(从 dev 检出)
  • 热修复分支:开发者自建分支,hotfix/问题描述 格式(从 dev 检出)

操作流程:

  1. dev 分支创建功能/修复分支
  2. 在功能分支上进行开发
  3. 开发完成后提交 Pull Request
  4. 代码审查通过后合并到 dev
  5. 不定期完整测试dev稳定后
  6. 合并到main,自动触发 CI/CD 流程,发布 Release 并打 Tag

完整测试频率建议:

  • 至少每周一次
  • 重要功能发布后
  • 紧急修复后

2.2 闭源版本(简化版 Git Flow

针对闭源版本的 Git Flow 工作流:

test 分支(测试环境)
  ↓ Developer 新建功能分支
feat/hotfix 分支
  ↓ 开发、测试
  ↓ Pull Request
  ↓ Review
  ↓ 测试测试人员拉取当前开发者的feature/hotfix分支对feature/hotfix进行测试  
test-cp (合并进test-cp分支测试)
  ↓ 完整测试  --> 失败回滚
test (合并进test分支)
  ↓ 合并test分支  
  ↓ 更新test环境    
main (合并回main分支)  
  ↓ 自动发布
Release Tag

分支规范:

  • main:生产环境稳定分支
  • test:测试环境分支(从 main 检出)-
  • test-cp:测试者的临时测试环境分支(从 test 检出)
  • 功能开发分支:开发者自建 feat/功能描述 格式(从 test 检出)
  • 热修复分支:开发者自建 hotfix/问题描述 格式(从 test 检出)

操作流程:

开发场景:

1. test → 创建 feat/f-support-sql-driver
2. feat/f-support-sql-driver → 开发完成后PR
3. 测试人员拉取当前开发者的feature/hotfix分支合并到 test-cp对test-cp进行测试
4. PR合并到 test
5. test测试验证通过 → 提交 PR 合并到 main
6. main → 完成自动触发 release 打 tag

3. 开源与闭源版本管理

3.1 仓库分离策略

上游 (开源版本)           下游 (闭源版本)
[公有仓库]              [私有仓库]
    |                       |
    |                       |
 开源核心代码 ←←←←←←←←←←←  商业版本完整代码
    |                       |
    |                       |
   社区贡献                 闭源功能

仓库结构:

  • 公有仓库:存放开源版本代码,所有人可访问
  • 私有仓库:存放商业版本完整代码(开源核心 + 闭源功能)

3.2 代码流向规范

单向流动原则:

  • 开源核心的所有改进新功能、Bug修复定期从公有仓库合并到私有仓库
  • 私有仓库中的闭源代码不流入公有仓库

3.3 实现方式

开源main分支发布后 团队讨论后决定是否合并到闭源

4. 操作步骤详解

4.1 开源版本操作步骤

新建功能开发:

# 1. 切换到 dev 分支并更新
git checkout dev
git pull origin dev

# 2. 创建功能分支
git checkout -b feat/功能描述

# 3. 开发并提交代码
git add .
git commit -m "功能描述"

# 4. 推送分支到远程仓库
git push origin feat/功能描述

# 5. 在 GitHub 上创建 Pull Request
# 6. 代码审查通过后合并到dev
# 7. dev不定期完整测试后并到main

4.2 闭源版本操作步骤

新建功能开发:

# 1. 切换到 test 分支并更新
git checkout test
git pull origin test

# 2. 创建功能分支
git checkout -b feat/功能描述

# 3. 开发并提交代码
git add .
git commit -m "功能描述"

# 4. 推送分支到远程仓库
git push origin feat/功能描述

# 5. 在 GitHub 上创建 Pull Request
# 6. 测试人员拉取当前开发者的feature/hotfix分支并到 test-cp对test-cp进行测试
# 7. 测试人员test-cp分支完整测试验证通过
# 8. 测试通过后PR合并到 test分支更新测试环境
# 9. 提交 PR 合并到 main
# 10. main → 完成自动触发 release 打 tag

5. 定期同步开源版本到闭源版本

为了确保闭源版本能够及时获得开源版本的改进,团队需要定期讨论是否将公有仓库的更新同步到私有仓库

同步频率建议:

  • 每周一次定期同步
  • 重要功能发布后立即同步
  • 紧急修复后立即同步

6. GitHub里程碑自动Release案例

可以使用 GitHub Actions 来实现基于里程碑的自动发布,创建 .github/workflows/auto-release.yml 文件:

name: Auto Release on Milestone Completion

on:
  milestone:
    types: [closed]
  workflow_dispatch:
    inputs:
      milestone_title:
        description: 'Milestone title to release'
        required: true

jobs:
  release:
    runs-on: ubuntu-latest
    steps:
      - name: Checkout code
        uses: actions/checkout@v3
        
      - name: Get milestone info
        id: milestone
        run: |
          if [ "${{ github.event_name }}" = "milestone" ]; then
            MILESTONE_TITLE="${{ github.event.milestone.title }}"
            MILESTONE_DESC="${{ github.event.milestone.description }}"
          else
            MILESTONE_TITLE="${{ github.event.inputs.milestone_title }}"
            MILESTONE_DESC=""
          fi
          
          echo "milestone_title=$MILESTONE_TITLE" >> $GITHUB_OUTPUT
          echo "milestone_description=$MILESTONE_DESC" >> $GITHUB_OUTPUT
          
      - name: Create release tag
        run: |
          git config --global user.name 'github-actions[bot]'
          git config --global user.email 'github-actions[bot]@users.noreply.github.com'
          git tag -a "v${{ steps.milestone.outputs.milestone_title }}" -m "${{ steps.milestone.outputs.milestone_description }}"
          git push origin "v${{ steps.milestone.outputs.milestone_title }}"
          
      - name: Create GitHub Release
        uses: actions/create-release@v1
        env:
          GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
        with:
          tag_name: "v${{ steps.milestone.outputs.milestone_title }}"
          release_name: "Release ${{ steps.milestone.outputs.milestone_title }}"
          body: |
            ## Release Notes
            ${{ steps.milestone.outputs.milestone_description }}
            
            ### Features
            - Feature 1
            - Feature 2
            
            ### Bug Fixes
            - Bug fix 1
            - Bug fix 2
            
          draft: false
          prerelease: false

使用说明:

  1. 当里程碑完成并关闭时,自动触发发布流程
  2. 根据里程碑标题创建版本标签(如 v1.0.0
  3. 自动生成 GitHub Release 页面
  4. 支持手动触发特定里程碑的发布

7. 冲突解决策略?

在将功能分支合并到 「test」/ 「dev」 分支时,可能会遇到代码冲突。为了解决这个问题并保持功能分支的独立性,推荐使用临时分支处理方式:

# 1. 创建临时分支用于解决冲突
git checkout -b test-tmp origin/test

# 2. 将功能分支合并到临时分支
git merge feat/功能分支名称

# 3. 解决冲突并提交
#    在编辑器中解决冲突文件
git add .
git commit -m "解决合并冲突"

# 4. 推送临时分支到远程仓库
git push origin test-tmp

# 5. 创建从 test-tmp 到 test 的 Pull Request
# 6. 代码审查通过后合并到 test 分支

# 7. 清理临时分支
git checkout test
git pull origin test
git branch -d test-tmp
git push origin --delete test-tmp

这种方式的优点:

  • 保持功能分支的独立性,不会被 「test」 分支污染 「test」 分支可能包含其他正在测试的功能特性,避免相互影响
  • 冲突解决过程在临时分支中进行,更加安全

8. 当前策略可能存在的问题

  • 需要建立完整测试流程与feature/hotfix测试流程
  • 需要专业测试人员,或者培训现有开发做测试
  • 开源版本dev完整测试的频率是否合适
  • 同步开源版本到闭源版本的频率是否合适

9. 分支模型合并流转图

角色说明

  • [开] 开发者Developer
  • [评] 评审者Reviewer
  • [维] 维护者Maintainer: 暂由Tester兼任
  • [测] 测试人员或测试责任(可由 Maintainer/CI/QA 共同承担)
  • [CI] CI/CD 系统(自动化构建/测试/发布)

9.1 开源版本分支模型

Feature/Hotfix 分支 ───● 从Dev检出创建分支[开]──────────● 开发&自测[开]──────────● 提交PR→dev[开]                               
                                                                   
                                                                                             
Dev 分支                 ● 接收PR/Review[评]───● 合并到 dev[评]───● dev 不定期完整测试[测/CI][通过?]───● 发起 PRdev→main[维]
                                                                  
                                                                   
Main 分支            ───● Review[评]───────────● 合并到 main[维]───────────● Release + Tag[CI]────────▶

9.2 闭源版本分支模型

Feature/Hotfix 分支 ───● 从Test检出创建分支[开]───────────● 开发&自测[开]──────────● 提交PR→test[开]      ● 修复并更新PR[开]────▶
                                                                                                   
                                                                                                    测试失败回路test 未通过 → 返回修复并更新 PR
Test 分支         ● 接收PR/Review[评]───● 合并到test-cp[维]───● 构建环境[CI]───● 回归测试[测][通过?]───● 合并进test发起PRtest→main[维]
                                                                                       
                                                                                     
Main 分支         ● Review[评]──────────● 合并到 main[维]──────────● Release + Tag[CI]────────▶

说明

  • 失败回路:若 test-cp 分支的完整测试未通过,返回到 Feature/Hotfix 的“修复并更新PR”开发者继续提交修复PR 自动更新,再次进入 Review→合并→测试流程。

9.3 跨仓库代码流转图

┌─────────────────────────────────────────────────────────────┐
│                    跨仓库代码流转模型                        │
└─────────────────────────────────────────────────────────────┘

[公有仓库 - 开源版本]               [私有仓库 - 闭源版本]
       │                                 │
       ▼                                 ▼
    新功能开发                        商业功能开发
       │                                 │
       ▼                                 ▼
    代码审查                         闭源功能集成
       │                                 │
       ▼                                 │
    合并到main                            │
       │                                 │
       ▼                                 ▼
    发布Release                   定期同步开源更新
       │                                 │
       └─────────────────────────────────┘
                   │
                   ▼
              版本兼容性测试

10. 最佳实践

  1. 提交信息规范:

    • 使用清晰、简洁的提交信息
    • 遵循约定式提交格式:<type>(<scope>): <subject>
  2. 分支命名规范:

    • 功能分支:feat/功能简述
    • 热修复分支:hotfix/问题简述
    • 使用英文小写字母,单词间用连字符分隔
  3. 代码审查:

    • 所有合并到主分支的代码必须经过代码审查
    • 审查人员应关注代码质量、功能正确性和安全性
  4. 定期同步:

    • 定期将开源版本的改进同步到闭源版本