首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为组织中的所有项目创建迭代

为组织中的所有项目创建迭代
EN

Stack Overflow用户
提问于 2020-10-11 18:41:41
回答 1查看 185关注 0票数 0

我们在Azure DevOps的产品级别有我们的项目,最后统计我们有94个产品。我需要找到一种方法,为所有项目创建相同的迭代(专门用于研发时间)。

我用邮递员试了一下:

代码语言:javascript
复制
 POST https://dev.azure.com/OrgName/Project1/_apis/wit/classificationnodes/Iterations?api-version=5.0

作为身体:

代码语言:javascript
复制
{"name": "Research and Development 2020-11-02", "attributes": {"startDate": "2020-11-02T00:00:00Z","finishDate": "2020-11-06T00:00:00Z"}}

它在某种程度上起了作用,因为它为我创建了一个项目的迭代,但是它最终在项目中丢失了(直到我在project中寻找它之前,它并没有在待定日志页面上显示为一个列出的sprint )。

是否有一种方法可以使用Postman循环遍历所有DevOps项目,以及如何删除迭代/sprint,使其可见,而无需在项目设置中跟踪它?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-10-12 02:52:52

是否有一种方法可以使用Postman循环遍历所有DevOps项目,以及如何删除迭代/sprint,使其可见,而无需在项目设置中跟踪它?

下面是一个powershell示例:

代码语言:javascript
复制
$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
       
        
    }
}

解释:

此示例可以遍历所有项目,同时创建迭代,最后将迭代添加到团队中。

第一个Rest用于列出项目名称。

第二个Rest用于创建一个迭代。

第三Rest用于将迭代添加到默认团队。然后,您可以在积压的日志中看到迭代。

在本例中,它是可见的,不需要在项目设置中跟踪它。

更新:

请尝试以下脚本:

代码语言:javascript
复制
$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", "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
       
        
    }
    }
}

Rest不支持排除项目(基于名称)。但是在Powershell中,您可以通过判断项目名称来排除这些项目。

代码语言:javascript
复制
$ExcludeList =  "Docker", "Azure"


   if ($ExcludeList | Where-Object {$project -like $_}) {
     
     echo $project
     echo "No Add"
   
   }

如果项目名称在列表中,项目将不会创建迭代。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64307758

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档