在VSTS发布管道中自动创建并关联待办事项的任务

45次阅读
没有评论

问题描述

在Microsoft的TFS/VSTS发布管道中寻求一种方法,在发布管道中自动创建一个任务,并将其附加到待办事项(Backlog Item)。他希望能够实现这一点,但目前尚未找到可以实现这个目标的方法。他想知道是否有人有办法实现这个需求。

解决方案

以下解决方案适用于TFS/VSTS及其相关工具和API。请根据您使用的具体版本和工具进行操作。

使用Azure DevOps Services REST API

通过Azure DevOps Services REST API,您可以编写自定义脚本或集成外部服务,实现在发布管道中自动创建任务并关联到待办事项。下面是一种可能的方法:

  1. 获取待办事项ID
    首先,您需要知道待办事项的ID,以便在任务中进行关联。您可以通过查询Azure DevOps的API来获取这些信息。

  2. 编写脚本或外部服务
    使用您喜欢的编程语言(如Python、PowerShell等),编写一个脚本或外部服务,以调用Azure DevOps Services REST API。在脚本中,您可以创建一个新的任务,并使用获取到的待办事项ID进行关联。以下是一个伪代码示例:

“`python
import requests

def create_task_and_link_to_backlog_item(backlog_item_id):
# 构建API请求URL
url = f”https://dev.azure.com/your_organization/your_project/_apis/wit/workitems/$Task?api-version=7.0″

   # 定义任务数据
   task_data = {
       "fields": {
           "System.Title": "Your Task Title",
           "System.AssignedTo": "John Doe",
           "System.State": "To Do",
           "System.RelatedLink": [
               {
                   "rel": "System.LinkTypes.Hierarchy-Reverse",
                   "url": f"https://dev.azure.com/your_organization/your_project/_apis/wit/workitems/{backlog_item_id}"
               }
           ]
       }
   }

   # 发送POST请求创建任务
   response = requests.post(url, json=task_data, auth=("username", "PAT"))

   if response.status_code == 200:
       print("Task created and linked successfully!")
   else:
       print("Failed to create and link task:", response.text)

# 调用函数并传入待办事项ID
create_task_and_link_to_backlog_item(“your_backlog_item_id”)
“`

  1. 在发布管道中执行脚本
    在您的发布管道中,添加一个适当的步骤,以调用上述脚本。您可以使用PowerShell任务或自定义脚本任务来执行这个脚本。

请注意,上述代码仅为示例,实际中您需要根据您的需求进行适当的调整。此外,确保在安全的环境下使用Personal Access Token(PAT)进行身份验证。

使用Azure DevOps Pipeline Tasks扩展

Azure DevOps Marketplace上有许多扩展可以帮助您实现在发布管道中自动创建任务并关联到待办事项。您可以搜索并找到适合您需求的扩展,例如”Create Work Item”等。

这些扩展通常会在发布管道中添加自定义任务,允许您通过配置界面设置任务的属性和关联,而无需编写脚本。

总结

通过使用Azure DevOps Services REST API或Azure DevOps Marketplace上的扩展,您可以实现在发布管道中自动创建任务并关联到待办事项的需求。根据您的偏好和要求,选择合适的方法进行操作。在使用API时,请确保遵循最佳实践和安全准则,以确保您的操作安全可靠。

注意:在执行任何操作前,请仔细阅读文档、测试您的解决方案,并确保备份重要数据。根据具体情况,操作可能会因版本差异或其他因素而有所不同。

正文完