在Azure DevOps中,我有一个管道变量“程序包版本”,并使用0.1.3$(Rev:.r)-alpha
进行了设置。
我使用该变量替换.net核心项目文件中的“版本”。
在构建任务中,dotnet构建给我这个错误:
因此,我假设Pipeline变量不能使用嵌套变量。
有别的方法或不同的语法可以做到吗?
[编辑]
嵌套变量应该起作用。
我认为错误是使用自动软件包版本控制的dotnet软件包设置为“使用内部版本号”,其中包含错误的$(rev:.r)
(小写!)。
在VS项目文件中为Version使用自定义字符串会给VS带来噪音(如果打开文件,则会出错,否则警告),现在由于版本无效,Pipeline Build在dotnet nuget restore上给我一个错误。
我决定使用一个简单的干净版本<Version>0.1.2</Version>
,可以选择并记录该版本。
然后,我想找到一种在构建管道中读取它的方法,并创建一个附加了Build Revision的自定义变量:
0.1.2 $(Rev:.r)=> 0.1.2.123
那就是我想要的结果。
我发现了这一点:https://marketplace.visualstudio.com/items?itemName=tmarkovski.projectversionasvariable
我使用的是默认设置。
我正在使用它创建的变量来组成一个新变量“程序包版本”:
我在nuget pack任务中使用了它:
但它不起作用。
结果变量仍包含未解析的“ $(Rev:.r)”。
我将尝试再次使用“自动软件包版本控制”,并在“选项”中创建内部版本号...
[编辑2]
在工作的“管道构建选项”中设置构建版本号。
这不是最佳解决方案,因为内部版本号未解析且看起来很糟糕。
[解]$(Rev:.r)
在构建/选项之外不可用。
我使用$(Build.BuildNumber)并可以创建一个组合变量:$(Version.MajorMinor).$(Build.BuildNumber)-alpha
Build.BuildNumber在Build / Options中具有价位:$(Build.DefinitionVersion)$(Rev:.r)
Version.MajorMinor由Project Version As Build Variable附加组件创建。
我不知道如何在不使用第三方组件的情况下获得相同的结果。
最佳答案
我很高兴我的扩展程序得到了帮助,并感谢您的好评。如果您需要更多控制权并且花一点时间来玩PowerShell,则可以通过两步轻松实现所需的功能,而无需使用第三方扩展。
读取.csproj文件并将其解析为XML
设置构建变量
这是阅读XML文件和使用构建变量的几个链接,实际上很简单。
https://www.business.com/articles/powershell-read-xml-files/
VSTS: Pass build/release variables into Powershell script task
[xml]$XmlDocument = Get-Content -Path $env:project_file
echo $XmlDocument.Project.PropertyGroup.Version
https://docs.microsoft.com/en-us/azure/devops/pipelines/process/variables?view=vsts&tabs=yaml%2Cbatch
Write-Host '##vso[task.setvariable variable=package_version;issecret=true]0.1.2.'
注意:我的答案不适合发表评论,我必须发布答案。
关于azure-devops - Azure DevOps-使用另一个变量(嵌套/组合变量)设置Build变量,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/53801928/