gitversion - 增加 csproj 版本并标记相同的提交

问题描述

我是 gitversion 的新手,正在努力达到我想要的效果。到目前为止,我们将升级 Version 文件.csproj 标记,提交,然后标记提交。结果:版本的标签在版本递增的同一个提交上。

然后我们切换到 gitversion,目的是让事情变得更加自动化。当我们想要更新版本时,我们现在运行 gitversion /updateprojectfiles。但是,问题在于版本是基于最后一个标签设置的(可能是由于我们的配置),因此版本的标签不能在包含此更改的提交中。换句话说,如果现在应该是 0.6.0 版本,运行上述命令仍会将其设置为 0.5.0,除非我们在更新之前进行标记(不理想)。

我可以做些什么不同的事情,仍然使用此命令并将标记放在升级 .csproj 文件中的版本的同一提交上?

GitVersion.yml 文件

branches:
  master:
    mode: ContinuousDeployment
    prevent-increment-of-merged-branch-version: true
    tag:
    increment: Patch
  develop:
    mode: ContinuousDeployment
    prevent-increment-of-merged-branch-version: false
    tag: alpha
    increment: Patch
  feature: {}
ignore:
  sha: []
merge-message-formats: {}

解决方法

执行 GitVersion 的目的是从 Git 元数据生成版本号,而不是相反。 GitVersion 将从同一分支上的同一提交生成相同的版本号,无论该提交是在何时何地构建的,因此您的稳定标签之间的所有中间版本号都不需要提交给 Git。

gitversion /updateprojectfiles 因此应该在 CI/CD 服务器上的构建期间执行,并且修改后的项目文件将被视为构建工件 - 不应提交给源代码控制。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...