从客户端对象API访问TFS团队查询

本文关键字:TFS 团队 查询 访问 API 客户端 对象 | 更新日期: 2023-09-27 18:27:11

是否有方法通过TFS 2013客户端对象API 按名称运行共享团队查询

我正在开发一个C#脚本,它将根据共享团队查询的结果进行一些工作。我不想在TFS UI和脚本中维护查询;我宁愿只运行我的团队使用的注册查询,但只处理结果。当我写"已注册查询"时,我只是指我在TFS UI中写的并保存为共享查询的查询。

换句话说:我想使用TFS UI创建一个查询,将文件保存在我的"共享查询"列表中,将其称为"foo",然后从脚本中的客户端对象API访问foo。

我看到WorkItemStore之外有一个GetQueryDefinition(GUID)方法,但我在哪里可以获得共享团队查询的GUID

从客户端对象API访问TFS团队查询

应该执行所需操作的示例代码

///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);
}