gpt4 book ai didi

azure-devops - Azure DevOps YAML 管道是否存在 "Create Work Item on Failure"选项?

转载 作者:行者123 更新时间:2023-12-04 14:13:07 24 4
gpt4 key购买 nike

在 Azure Devops“经典”管道中,管道选项菜单中有一个部分,您可以在其中打开一项功能,以在管道出现故障时自动创建工作项。但是,在新的 YAML 管道中,选项菜单中不存在此功能。这个选项是否仍然以某种方式可用,或者它不支持 YAML 管道?

最佳答案

尽管此选项目前无法通过 YAML 管道的 GUI 使用,但它仍然可以在后台运行 - 只是没有一种简单的方法可以打开它。但是,您可以通过使用 Azure DevOps REST API 来实现。
首先,您需要知道 Azure DevOps 组织、项目和管道的定义 ID 的名称,这是查看给定管道时 URL 上的查询字符串参数,例如https://dev.azure.com/{organization}/{project}/_build?definitionId={definition id}。然后,您需要使用以下 URL 格式向 Pipelines API 发送 GET 请求以获取该 ID: https://dev.azure.com/{organization}/{project}/_apis/build/definitions/{definition id}?api-version=5.1 。对于身份验证,您应该能够使用基本身份验证,将用户名留空并使用适当范围的个人访问 token 作为密码。
如果您的请求成功,您应该会收到一个响应,其中包含一个描述相关管道的大型 JSON 对象。有很多不相关的,但我们正在寻找的是接近顶部的:有一个 options 数组,其中包含以下元素:

...
{
"enabled": false,
"definition": {
"id": "a9db38f9-9fdc-478c-b0f9-464221e58316"
},
"inputs": {
"workItemType": "Task",
"assignToRequestor": "true",
"additionalFields": "{}"
}
},
...
ID "a9db38f9-9fdc-478c-b0f9-464221e58316" 在所有管道中似乎都是静态的,并且唯一标识了在失败时创建工作项的选项。如果我们编辑 JSON 以将 "enabled": false" 更改为 true(并在 inputs 字段中设置任何其他所需的选项),我们现在可以从 GET 请求中获取整个 JSON 响应,并将其用作第二个 API 调用的主体相同的 URL,这次是 PUT 请求。如果一切正常,您应该会看到更新后的更改反射(reflect)在 PUT 的响应中。
这有点笨拙,因为仍然无法通过 Web UI 验证该选项是否已打开,但在 Microsoft 更新 UI 以包含此功能之前,它是可用的最佳选项。一个更方便的提示是,如果您已经有一个经典模式管道,您向 UI 添加了附加字段或其他自定义项,您可以在该管道上执行 API GET 以提取这些设置的确切 JSON 并使用它们来通知您的 PUT 到您的 YAML 管道。

关于azure-devops - Azure DevOps YAML 管道是否存在 "Create Work Item on Failure"选项?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62757795/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com