Как пакетное обновление нескольких рабочих элементов в TFS - PullRequest
30 голосов
/ 31 июля 2009

Мне нужно обновить одно и то же поле до того же значения для сотен рабочих элементов в TFS. Есть ли способ сделать это в пакете, вместо того, чтобы обновлять их вручную по одному?

Ответы [ 2 ]

42 голосов
/ 31 июля 2009

Вы можете сделать это в Excel :

  1. Откройте рабочие элементы в Excel с помощью:
    • щелкните правой кнопкой мыши запрос в Team Explorer -> открыть в Excel
    • выберите несколько рабочих элементов в области результатов WIT, затем щелкните правой кнопкой мыши -> открыть в Excel
    • загрузить Excel, использовать Team -> Import, чтобы загрузить предопределенный запрос
    • открыть файл * .xls, который уже связан с TFS
  2. Сделайте ваши массовые правки
  3. Нажмите кнопку «Опубликовать» на ленте команды

enter image description here

Полная документация: Управление рабочими элементами в Excel (обзорная страница; множество ссылок внутри)

Вы также можете массово редактировать в веб-интерфейсе

Командная строка Windows :

REM make Martin Woodward fix all my bugs
tfpt query /format:id "TeamProject\public\My Work Items" | 
    tfpt workitem /update @ /fields:"Assigned To=Martin"

Powershell

# make Bill & Steve happy
$tfs = tfserver -path . -all
$items = $tfs.wit.Query("
    SELECT id FROM workitems 
    WHERE [Created By] IN ('bill gates', 'steve ballmer')") | 
    % {
        $_.Open()
        $_.Fields["priority"].value = 1
        $_
    }
# note: this will be much faster than tfpt since it's only one server call
$tfs.wit.BatchSave($items)   
0 голосов
/ 18 ноября 2016
$secpasswd = ConvertTo-SecureString $TfsPasswd -AsPlainText -Force
$mycreds = New-Object System.Management.Automation.PSCredential ($TfsUserName, $secpasswd)
Connect-TfsTeamProjectCollection -Server $TfsServerUrl -Collection $TfsCollection -Credential $mycreds
#Get-TfsTeamProject

Connect-TfsTeamProject -Project $TfsProjectName
$workItems  = Get-TfsWorkItem -Filter "[System.WorkItemType] = 'Bug' AND [System.AssignedTo] = '$TfsUserName'"
foreach ($workItem in $workItems)
{
    $tpc = $workItem.Store.TeamProjectCollection
    $id = $workItem.Id
    $store = $tpc.GetService([type]'Microsoft.TeamFoundation.WorkItemTracking.Client.WorkItemStore')
    $wi = $store.GetWorkItem($id)
    $projectName = $wi.Project.Name
    foreach($fldName in $Fields.Keys)
    {
        $wi.Fields[$fldName].Value = $Fields[$fldName]
    }
    $wi.Save()
}

Вы можете скачать подробный скрипт из , как выполнить пакетное обновление нескольких рабочих элементов в TFS с помощью PowerShell

...