是否有办法按名称通过TFS 2013客户端对象API
运行共享团队查询我正在开发一个C#脚本,它将根据共享团队查询的结果进行一些工作。我不想在TFS用户界面和脚本中维护查询;我宁愿只运行我的团队使用的注册查询,但只是玩结果。当我写“注册查询”时,我只是指我在TFS UI中编写的一个查询,并保存为共享查询。
换句话说:我想使用TFS UI创建查询,将文件保存在“共享查询”列表中,将其命名为“foo”,然后在我的脚本中从客户端对象API访问foo。
我发现GetQueryDefinition(GUID)
有一个WorkItemStore
方法,但我会在哪里获得共享团队查询的GUID
?
答案 0 :(得分:14)
应该做你需要的示例代码
///Handles nested query folders
private static Guid FindQuery(QueryFolder folder, string queryName)
{
foreach (var item in folder)
{
if (item.Name.Equals(queryName, StringComparison.InvariantCultureIgnoreCase))
{
return item.Id;
}
var itemFolder = item as QueryFolder;
if (itemFolder != null)
{
var result = FindQuery(itemFolder, queryName);
if (!result.Equals(Guid.Empty))
{
return result;
}
}
}
return Guid.Empty;
}
static void Main(string[] args)
{
var collectionUri = new Uri("http://TFS/tfs/DefaultCollection");
var server = new TfsTeamProjectCollection(collectionUri);
var workItemStore = server.GetService<WorkItemStore>();
var teamProject = workItemStore.Projects["TeamProjectName"];
var x = teamProject.QueryHierarchy;
var queryId = FindQuery(x, "QueryNameHere");
var queryDefinition = workItemStore.GetQueryDefinition(queryId);
var variables = new Dictionary<string, string>() {{"project", "TeamProjectName"}};
var result = workItemStore.Query(queryDefinition.QueryText,variables);
}