[Azure DevOps] 如何使用任务组
1. 使用 PowerShell 脚本#
在上一篇文章中我们学会了怎么使用扩展在编译前实时更改版本号。有些情况下我们希望不适用扩展,例如喜欢发明轮子,或者根本没有安装扩展的权限。这时候我们可以自己写 PowerShell 解决这个问题。
在 Pipeline 中添加一个 PowerShell 的任务,Type 选择 Inline,然后在 Script 里输入这段 PowerShell 脚本:
$ComponentPath = $Env:Build_SourcesDirectory
$VersionNumber = $Env:AssemblyVersion+"."+$Env:Build_BuildId+".0"
$ErrorActionPreference = "Stop"
Write-Output "ComponentPath""$ComponentPath""."
Write-Output "VersionNumber""$VersionNumber""."
$assemblyFiles = Get-ChildItem -Recurse -Path $ComponentPath -Include AssemblyInfo.cs | Where-Object { $_.fullname -notmatch "\\packages\\" }
$assemblyVersionRegex = New-Object System.Text.RegularExpressions.Regex -ArgumentList '^\s*\[assembly:\s*AssemblyVersion\("[^"]*"\)\]',MultiLine
$assemblyFileVersionRegex = New-Object System.Text.RegularExpressions.Regex -ArgumentList '^\s*\[assembly:\s*AssemblyFileVersion\("[^"]*"\)\]',MultiLine
$assemblyInfoVersionRegex = New-Object System.Text.RegularExpressions.Regex -ArgumentList '^\s*\[assembly:\s*AssemblyInformationalVersion\("[^"]*"\)\]',Multiline
foreach ($file in $assemblyFiles)
{
$content = [System.IO.File]::ReadAllText($file)
$assemblyVersionReplacement = [string]::Format("[assembly: AssemblyVersion(""{0}"")]", $VersionNumber)
$assemblyFileVersionReplacement = [string]::Format("[assembly: AssemblyFileVersion(""{0}"")]", $VersionNumber)
$assemblyInfoVersionReplacement = [string]::Format("[assembly: AssemblyInformationalVersion(""{0}"")]", $VersionNumber)
$content = $assemblyVersionRegex.Replace($content, $assemblyVersionReplacement)
$content = $assemblyFileVersionRegex.Replace($content, $assemblyFileVersionReplacement)
$content = $assemblyInfoVersionRegex.Replace($content, $assemblyInfoVersionReplacement)
[System.IO.File]::WriteAllText($file, $content)
Write-Output "Updated file ""$file"" to have version ""$VersionNumber""."
}
上面这段 PowerShell 的作用是修改项目里的 AssemblyInfo.cs
,将版本号改为 $Env:AssemblyVersion+"."+$Env:Build_BuildId+".0"
。有了这个 Task,我们可以不再依赖扩展来实现这个功能。
需要注意的是,在 PowerShell 里使用 Azure Pipelines 的变量的格式是 $Env:
+ 变量名,变量名里的句号 .
要改为下划线 _
,例如 $(Build.BuildId)
在 PowerShell 里的引用方式为 $Env:Build_SourcesDirectory
。
2. 使用任务组#
下一步,为了不在每个 Pipeline 中复制粘贴这个 Task 及其中的 PowerShell 脚本,我们需要把这个 Task 做成一个公共的东西。这时候可以使用任务组 ,它可以将已在生成或发布管道中定义的一系列任务封装到可添加到生成或发布管道中的单个可重用任务,就像任何其他任务一样。不过需要注意的是 YAML 管道不支持任务组,任务组只能用在经典管道中。
创建任务组的方式如下图所示,在任务列表中选中一个或多个任务,然后在右键菜单中选中 Create task group,在弹出的对话框中输入名称,选择分类,最后点击 Create 完成创建。
创建任务组后,之前选中的任务就原地转换为新的任务组。
这个任务组的使用方式其它任务一样,在 Add tasks 里添加到 Pipeline 即可。
3. 管理任务组#
在左边的菜单中选中 Task groups 进入任务组列表的页面,在列表中选中要管理的任务组进入任务组的详细页面。
在 Task 页中可以像在 Pipeline 中管理任务一样管理任务组的任务,也可以修改任务组的名称、分类、版本号等信息。
在 History 页中可以查看更改的历史记录。
在 References 页中可以看到任务组被引用的 Build pipelines、Release Pipelines、Task groups。
4. 最后#
任务组是一个很好用的功能,可惜在 YAML 管道中不能使用。有关任务组的更多内容可以参考官方文档:
作者:Dino.C
出处:https://www.cnblogs.com/dino623/p/how-to-use-task-group.html
版权:本文采用「CC BY 4.0」知识共享许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?