如何解决为组织中的所有项目创建迭代
我们在Azure DevOps中将产品放在产品级别,最后我们有94个产品。我需要找到一种方法,就是为所有项目创建相同的迭代(专用于研发时间)
我使用邮递员尝试了此操作:
POST https://dev.azure.com/OrgName/Project1/_apis/wit/classificationnodes/Iterations?api-version=5.0
这是正文:
{"name": "Research and Development 2020-11-02","attributes": {"startDate": "2020-11-02T00:00:00Z","finishDate": "2020-11-06T00:00:00Z"}}
之所以有效,是因为它为我为一个项目创建了一个迭代,但是最终却在项目中迷失了(直到我在“项目设置”中寻找它,它才在积压页面上显示为列出的sprint。 )。
有没有一种方法可以使用Postman遍历所有DevOps项目,还应该如何放置迭代/冲刺以使其可见,而无需在项目设置上进行追踪?
解决方法
有没有一种方法可以使用Postman遍历所有DevOps项目,还应该如何放置迭代/冲刺以使其可见,而无需在项目设置上进行追踪?
这是一个powershell示例:
$token = "PAT"
$url="https://dev.azure.com/{Organization}/_apis/projects?api-version=6.0"
$token = [System.Convert]::ToBase64String([System.Text.Encoding]::ASCII.GetBytes(":$($token)"))
$response = Invoke-RestMethod -Uri $url -Headers @{Authorization = "Basic $token"} -Method Get -ContentType application/json
ForEach( $project in $response.value.name )
{
$url1="https://dev.azure.com/{Organization name}/$($project)/_apis/wit/classificationnodes/Iterations?api-version=5.0"
$JSON = @'
{
"name": "Research9","attributes": {"startDate": "2020-11-02T00:00:00Z","finishDate": "2020-11-06T00:00:00Z"}
}
'@
$response1 = Invoke-RestMethod -Uri $url1 -Headers @{Authorization = "Basic $token"} -Method Post -Body $JSON -ContentType application/json
ForEach($id in $response1.identifier)
{
echo $id
echo $project
$url2="https://dev.azure.com/{Organization name}/$($project)/_apis/work/teamsettings/iterations?api-version=6.0"
$body = "{
`"id`": `"$id`"
}"
$response2 = Invoke-RestMethod -Uri $url2 -Headers @{Authorization = "Basic $token"} -Method Post -Body $body -ContentType application/json
}
}
说明:
该示例可以遍历所有项目,同时创建迭代,最后将Iteration添加到团队中
first Rest API用于列出项目名称。
Second Rest API用于创建迭代。
Third Rest API用于将迭代添加到默认组。然后您可以在待办事项列表中看到迭代。
在这种情况下,无需查看项目设置即可看到它。
更新:
请尝试以下脚本:
$token = "PAT"
$url="https://dev.azure.com/{Organization Name}/_apis/projects?api-version=6.0"
$token = [System.Convert]::ToBase64String([System.Text.Encoding]::ASCII.GetBytes(":$($token)"))
$response = Invoke-RestMethod -Uri $url -Headers @{Authorization = "Basic $token"} -Method Get -ContentType application/json
$ExcludeList = "Docker","Azure","ProjectNAME"
ForEach( $project in $response.value.name )
{
if ($ExcludeList | Where-Object {$project -like $_}) {
echo $project
echo "No Add"
}
else{
$url1="https://dev.azure.com/{Organization name}/$($project)/_apis/wit/classificationnodes/Iterations?api-version=5.0"
$JSON = @'
{
"name": "Research10","finishDate": "2020-11-06T00:00:00Z"}
}
'@
$response1 = Invoke-RestMethod -Uri $url1 -Headers @{Authorization = "Basic $token"} -Method Post -Body $JSON -ContentType application/json
ForEach($id in $response1.identifier)
{
echo $id
echo $project
$url2="https://dev.azure.com/{Organization Name}/$($project)/_apis/work/teamsettings/iterations?api-version=6.0"
$body = "{
`"id`": `"$id`"
}"
$response2 = Invoke-RestMethod -Uri $url2 -Headers @{Authorization = "Basic $token"} -Method Post -Body $body -ContentType application/json
}
}
}
Rest API不支持排除项目(基于名称)。但是在Powershell中,您可以通过判断项目名称来排除这些项目。
$ExcludeList = "Docker","Azure"
if ($ExcludeList | Where-Object {$project -like $_}) {
echo $project
echo "No Add"
}
如果项目名称在列表中,则该项目将不会创建迭代。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。