git - GitVersion 构建元数据未正确递增
问题描述
我正在为 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: {}
我不明白为什么?
有人可以帮我吗?
解决方案
问题是当分支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 策略中的发布分支
推荐阅读
- excel - 在 Excel 中计算数据时的平均时间差
- python - pyparsing 获取所有被忽略的评论文本
- javascript - Javascript:.prototype.constructor 的目的是什么?
- flutter - 如何使用 FieldValue.Increment 属性添加单值颤振
- php - 如何使用 php 在图像中编写印地语文本属性
- java - 按J按钮画一个球,球是不可见的
- python - Python3 Raspberry Pi (ModuleNotFoundError: No module named 'RPi') with code and error and RPi.GPIO version
- github - GitHub Actions 对于 PRIVATE Repositories 是否安全且私密?
- servlets - Tomcat7 Maven 插件服务未找到
- javascript - 有没有办法将事件侦听器应用于整个元素类?