构建成功后如何自动创建Build Pipeline TAG(不是GIT TAG)?

问题描述 投票:0回答:2

到目前为止的故事:

  • 当我有一个想要部署的提交时,我会创建一个 GIT 标签作为构建的基础,例如“RC1”
  • GIT TAG的创建会自动触发PipeLine Build启动。
  • 成功完成 PipeLine Build 后,它会在源提交上创建一个新的 GIT TAG,并使用 BuildNumber_BuildId 以便稍后交叉引用。
  • 我还有一个发布管道,然后用于进行部署(我喜欢分离),我想过滤 Build TAG =“RC*”
  • 我可以手动创建构建标签,但是....

这就是需要帮助的地方。

我花了好几天的时间寻找一种自动创建 PipeLine Build TAG 的方法,但只找到了我已有的答案。如果它是 YAML 中的步骤/任务或构建管道中的设置,我可能不会。如果有人能指出我正确的方向,我将不胜感激。

最终目标是如果构建成功,将原始源GIT TAG推送到Build TAG中。

注意:我仅在 YAML 中工作,并且 Azure Devops 版本 Dev18.M170.1 原生提供任何设置,即没有插件。

azure-devops azure-pipelines continuous-delivery
2个回答
13
投票

如果仍处于构建阶段,您可以添加构建标签,从脚本、bash或PowerShell运行以下命令(write-host而不是echo)任务:

echo ##vso[build.addbuildtag]My Tag

在 Yaml 中,最简单的语法是:

- script: |
    echo ##vso[build.addbuildtag]My Tag

或者对于 PowerShell,您可以使用简短语法:

steps:
- powershell: |
    $newSourceBranch = "$(Build.SourceBranch)" -replace 'refs/tags/', '' 
    $Command = "##vso[build.addbuildtag]"+$newSourceBranch 
    write-host "Create a Build TAG called $newSourceBranch" 
    write-host $Command

8
投票

当然。构建成功后,您可以使用 API“Tags - 添加构建标签”来添加标签。

如果您想同时为成功构建添加多个标签,可以使用API“Tags - 添加构建标签”。

下面是一个为成功构建添加标签的演示。您可以引用它并在构建管道中设置相关步骤。

对于经典构建管道:

  1. 在构建作业的设置页面上启用选项“允许脚本访问 OAuth 令牌”。

  2. 添加 PowerShell 任务作为构建作业的最后一个。

    • 选择“仅当所有先前任务都成功时才运行此任务
    • 将以下脚本添加到任务中。将
      {organization}
      {project}
      {tag}
      替换为您想要的实际组织、项目和标签。
    $headers = New-Object "System.Collections.Generic.Dictionary[[String],[String]]"
    $headers.Add("Authorization", "Bearer $env:SYSTEM_ACCESSTOKEN")
    $headers.Add("Content-Type", "application/json")
    $uri = "https://dev.azure.com/{organization}/{project}/_apis/build/builds/$(Build.BuildId)/tags/{tag}?api-version=6.0"
    Invoke-RestMethod -Uri $uri -Headers $headers -Method PUT
    

对于 YAML 构建管道:

添加一个 PowerShell 任务作为构建作业的最后一个任务,如下所示。将

{organization}
{project}
{tag}
替换为您想要的实际组织、项目和标签。

jobs:
- job: build
  displayName: 'Build job'
  . . .
  steps:
  . . .
  - task: PowerShell@2
    displayName: 'Add Build Tag'
    condition: succeeded()  # Only when all previous tasks have succeeded
    env:
      SYSTEM_ACCESSTOKEN: $(System.AccessToken)
    inputs:
      targetType: inline
      script: |
        $headers = New-Object "System.Collections.Generic.Dictionary[[String],[String]]"
        $headers.Add("Authorization", "Bearer $env:SYSTEM_ACCESSTOKEN")
        $headers.Add("Content-Type", "application/json")
        $uri = "https://dev.azure.com/{organization}/{project}/_apis/build/builds/$(Build.BuildId)/tags/{tag}?api-version=6.0"
        Invoke-RestMethod -Uri $uri -Headers $headers -Method PUT

结果:

© www.soinside.com 2019 - 2024. All rights reserved.