3

我正在为 AzureDevOps 使用 Gitversion 任务 5.1.2。

我的分支策略是 GitFlow。

从开发分支输出:

Base version used: Git tag '3.0.0-beta.5': 3.0.0-beta.5 with commit count source 35fb4fe5e51526375e94f61dfc3cca421d235c11 (Incremented: 3.0.0-beta.6)

我期待的是3.0.0-beta.6,从上面的行我可以看到它正确计算了元数据,到目前为止还不错,但最后更新号是3.0.0-beta.1,如下图.

  INFO [11/27/19 19:13:42:97] 1 commits found between 35fb4fe5e51526375e94f61dfc3cca421d235c11 and c6bf7b9b86727f1fcd944dc32d7e34be57e4c0cc
  INFO [11/27/19 19:13:43:00] Begin: Creating dictionary
  INFO [11/27/19 19:13:43:01] End: Creating dictionary (Took: 8.32ms)
  INFO [11/27/19 19:13:43:02] Begin: Storing version variables to cache file D:\a\1\s\.git\gitversion_cache\0DA5D62C7623C962136858D6D06616CC294FEB91.yml
  INFO [11/27/19 19:13:44:07] End: Storing version variables to cache file D:\a\1\s\.git\gitversion_cache\0DA5D62C7623C962136858D6D06616CC294FEB91.yml (Took: 1,053.64ms)
  INFO [11/27/19 19:13:44:43] Applicable build agent found: 'VsoAgent'.
Executing GenerateSetVersionMessage for 'VsoAgent'.
Executing GenerateBuildLogOutput for 'VsoAgent'.
  INFO [11/27/19 19:13:44:45] Updating assembly info files
  INFO [11/27/19 19:13:44:47] Found 1 files
##[section]Async Command Start: Update Build Number
Update build number to 3.0.0-beta.1 for build 4043

我的 GitVersion.yml

mode: ContinuousDelivery
branches:
  master:
    regex: master
    tag: ''
  release:
    regex: releases?[/-]
    tag: rc
  feature:
    regex: features?[/-]
    tag: alpha
  develop:
    regex: dev(elop)?(ment)?$
    mode: ContinuousDeployment
    tag: beta
ignore:
  sha: []
merge-message-formats: {}

我不明白为什么?

有人可以帮我吗?

4

1 回答 1

2

问题是当分支release/2.2.0合并回开发时,在 GitVersion.yml 中有next-version: 3.0.0标签并且提交计数为 5。因此 GitVersion 创建了构建版本号 3.0.0.beta.5。到目前为止,一切都很好,但是这种合并以某种方式重置了提交计数。

在下一个拉取请求中,结果是,即使next-version: 3.0.0不再有标签,但已经有标签 3.0.0.beta.5 并且它之前已经计算了正确的增量,GitVersion 选择了 3.0.0 作为版本号并使用提交计数添加元数据 beta.1,以创建Update build number to 3.0.0-beta.1

我的方法是更改​​ GitVersion.yml 文件如下:

next-version: 3.1.0
mode: ContinuousDelivery
branches:
  master:        
    regex: master    
    tag: ''    
    increment: Patch
    prevent-increment-of-merged-branch-version: true
    track-merge-target: false
    tracks-release-branches: false
    is-release-branch: false
  release:
    tag: rc
    tracks-release-branches: false
    is-release-branch: true    
  develop:
    tag: beta
    increment: Minor
    tracks-release-branches: true
    is-release-branch: false
ignore:
  sha: []
merge-message-formats: {}

我用:

  • next-version 3.1.0=> 强制下一个版本创建标签 3.1.0.beta.2 而不是 3.0.0.beta.2。这是一次性的事情,只是为了回到正确的轨道上。

  • increment=> 告诉GitVersion在每个分支中增加哪一部分,release默认为none;

  • tracks-release-branches => 告诉 GitVersion 该分支是或不是 Gitflow 策略中的开发分支

  • is-release-branch=> 告诉 GitVersion 该分支是或不是 Gitflow 策略中的发布分支

于 2019-12-04T19:44:14.913 回答