2016-12-15 29 views
1

在此提到:Using the TFS REST API to get all work items in an iteration ,我已经与VS文档在https://www.visualstudio.com/en-us/docs/integrate/api/wit/queries#get-a-query-or-folder将TFS REST API与存储查询一起使用时是否已编译?

工作我们尝试基于TFS的服务器上存储的查询更改日志文本文件。在REST API之前,我们使用VS 2012/2013 TFS库,但现在正在转向REST。

现在通过阅读我看到查询工作项目时,我应该为最多做到这一点的文档200的工作项(https://www.visualstudio.com/en-us/docs/integrate/api/wit/wiql#get-work-items

如果我理解正确的文件,然后我需要一个存储查询6次HTTP的查询返回607个工作项目。

  1. 按名称获取存储查询 - > http://server/Project/_apis/wit/queries/Shared%20Queries/Change%20Log?api-version=1.0&$expand=all,它返回WIQL网址查询
  2. 查询WIQL - >返回607个IDS
  3. 前200个工作项目创建一个工作项查询
  4. 下一个200
  5. 用于下一200
  6. 未来7

然后按照查询号提供的显示列配置组装这些工作项并对其进行格式化。 1.

通过测试200工作项目的限制,我发现on-premise安装实际上允许更多的工作项目。目前,工作项目的最大数量由GET请求长度2096(在TFS 2017上测试)定义。

这是确认如何执行存储查询的方法吗?

回答

3

是的,这是正确的做法。

简单的C#代码发送REST API:

String MyURI = "[REST API URL]"; 
      WebRequest WReq = WebRequest.Create(MyURI); 
      WReq.Credentials = 
       new NetworkCredential("[user name]", "[password]", "[domain]"); 

      WebResponse response = WReq.GetResponse(); 
      Console.WriteLine(((HttpWebResponse)response).StatusDescription); 
      // Get the stream containing content returned by the server. 
      Stream dataStream = response.GetResponseStream(); 
      // Open the stream using a StreamReader for easy access. 
      StreamReader reader = new StreamReader(dataStream); 
      // Read the content. 
      string responseFromServer = reader.ReadToEnd(); 
      // Display the content. 
      Console.WriteLine(responseFromServer); 

在另一方面,你可以run the query with WIQL string

关于获取存储查询的WIQL字符串,可以使用TFS .net客户端API。

NetworkCredential cred = new NetworkCredential("[user name]", "[password]", "[domain]"); 
      TfsTeamProjectCollection tpc = new TfsTeamProjectCollection(new Uri("[collection URL"), cred); 
      tpc.EnsureAuthenticated(); 
      WorkItemStore wis = tpc.GetService(typeof(WorkItemStore)) as WorkItemStore; 
QueryHierarchy queryRoot = wis.Projects["[team project]"].QueryHierarchy; 
      QueryFolder queryFolder = queryRoot["Shared Queries"] as QueryFolder; 
      QueryDefinition qd = queryFolder["PBIS"] as QueryDefinition; 
      string tt = qd.QueryText; 

关于与Extended Client package电话查询REST API,你可以参考这个简单的代码:

var u = new Uri("[collection url]"); 
VssCredentials c = new VssCredentials(new Microsoft.VisualStudio.Services.Common.WindowsCredential(new NetworkCredential("v-stache", "[email protected]", "fareast"))); 
      var connection = new VssConnection(u, c); 
      var workitemClient = connection.GetClient<WorkItemTrackingHttpClient>(); 
var result = workitemClient.QueryByWiqlAsync(new Microsoft.TeamFoundation.WorkItemTracking.WebApi.Models.Wiql() { Query = "select[System.Id] from WorkItems where [System.TeamProject] = 'ScrumStarain2' and [System.WorkItemType] = 'Product Backlog Item' and [System.State] <> ''" }, "ScrumStarain2").Result; 
+0

我们使用TFS .NET客户端API,但它似乎不再可用在2015年。我们与2015年的CI只建立代码,但最终会丢失卫星组件。 – Samuel

+0

@Samuel TFS客户端API仍然适用于2015年,您可以为您的问题打开新的线程。 –

+0

@samuel,2015年的客户端API作为“Team Foundation Server扩展API”在Nuget上提供......只需将其添加到您的项目中即可。 –

相关问题