Как собрать всех пользователей вместе с Team Iteration проекта TFS WIQL?
Я хочу получить всех пользователей с итерацией в проекте. Допустим, в проекте "Precient" 9 разных пользователей с 20 итерациями, поэтому я хочу, чтобы у всех пользователей была итерация в проекте. WIQL C#
Это связано с вопросом. WIQL-запрос, чтобы получить всю команду и пользователей в проекте?
но не помогает мне полностью
2 ответа
Вы можете получить это через REST API или Net API. Это образец для Net API.
- Вы можете получить всех пользователей из группы "Project Valid Users"
Вы можете получить все итерации из корневых итераций проекта.
using Microsoft.TeamFoundation.Client; using Microsoft.TeamFoundation.Framework.Client; using Microsoft.TeamFoundation.Framework.Common; using Microsoft.TeamFoundation.Server; using Microsoft.TeamFoundation.WorkItemTracking.Client; using System; using System.Collections.Generic; namespace GetUserіAndItearions { class Program { public class Iteration { public string Path; public DateTime DateFrom; public DateTime DateTo; } static void Main(string[] args) { string _teamProject = "Your_Project_Name"; try { TfsTeamProjectCollection _tpc = new TfsTeamProjectCollection(new Uri("http://your_server:8080/tfs/DefaultCollection")); GetAllUsers(_tpc, _teamProject); GetAllIterations(_tpc, _teamProject); } catch (Exception ex) { Console.WriteLine("Error: " + ex.Message); Console.WriteLine(ex.StackTrace); } } private static void GetAllIterations(TfsTeamProjectCollection pTpc, string pProjectName) { List<Iteration> _its = new List<Iteration>(); WorkItemStore _wistore = pTpc.GetService<WorkItemStore>(); var _css = pTpc.GetService<ICommonStructureService4>(); foreach (Node _node in _wistore.Projects[pProjectName].IterationRootNodes) FillIterations(_css, _node, _its); Console.WriteLine("Iterations:"); foreach (Iteration _it in _its) Console.WriteLine("{0}:{1}-{2}", _it.Path, (_it.DateFrom == DateTime.MinValue) ? "0" : _it.DateFrom.ToShortDateString(), (_it.DateTo== DateTime.MinValue) ? "0" : _it.DateTo.ToShortDateString()); } private static void FillIterations(ICommonStructureService4 pCss, Node pNode, List<Iteration> pIts) { var _nodeInfo = pCss.GetNode(pNode.Uri.AbsoluteUri); pIts.Add(new Iteration { Path = _nodeInfo.Path, DateFrom = (_nodeInfo.StartDate == null) ? DateTime.MinValue : (DateTime)_nodeInfo.StartDate, DateTo = (_nodeInfo.FinishDate == null) ? DateTime.MinValue : (DateTime)_nodeInfo.FinishDate }); if (pNode.HasChildNodes) foreach (Node _node in pNode.ChildNodes) FillIterations(pCss, _node, pIts); } private static void GetAllUsers(TfsTeamProjectCollection pTpc, string pProjectName) { List<string> listUsers = new List<string>(); WorkItemStore _wistore = pTpc.GetService<WorkItemStore>(); var _gss = pTpc.GetService<IIdentityManagementService>(); var _teamProject = _wistore.Projects[pProjectName]; string _validGroupName = "[" + pProjectName + "]\\Project Valid Users"; TeamFoundationIdentity _group = _gss.ReadIdentity(IdentitySearchFactor.DisplayName, _validGroupName, MembershipQuery.Expanded, ReadIdentityOptions.ExtendedProperties); List<string> _memebersIds = new List<string>(); foreach (var _member in _group.Members) _memebersIds.Add(_member.Identifier); var _members = _gss.ReadIdentities(IdentitySearchFactor.Identifier, _memebersIds.ToArray(), MembershipQuery.Expanded, ReadIdentityOptions.ExtendedProperties); foreach (var _member in _members) if (!_member[0].IsContainer) listUsers.Add(_member[0].DisplayName); Console.WriteLine("Users:"); foreach (var _user in listUsers) Console.WriteLine("{0}", _user); } } }
Он не может получить пользователей из команды через WIQL. WIQL - это язык запросов рабочих элементов, который используется для поиска ошибок, задач, других типов рабочих элементов. Возвращаемое значение должно быть рабочим элементом.
Вам нужно использовать api как @Shamray, предоставленный для получения пользователей. Следующий блог также предоставил пример:
http://blogs.microsoft.co.il/shair/2012/05/20/tfs-api-part-44-vs11-teams-and-team-members/