我的最终目标是递归地获取一个工作项的父项,直到层次结构中没有更多的父项。目前还没有递归的实现,我仍在优化获取父项的方式。我考虑使用一种查询的方式来完成这个任务:
public WorkItem GetParentWorkItem(int id)
{
StringBuilder queryString = new StringBuilder("SELECT [System.Id]" +
" FROM WorkItemLinks " +
" WHERE [Source].[System.WorkItemType] = '" + TFS_TIMESHEET_WORK_ITEM_TYPE + "'" +
" AND [Source].[System.TeamProject] = '" + TFS_TIMESHEET_PROJECT_KEY + "'" +
" AND [Source].[System.Id] = " + id
);
Query wiQuery = new Query(GetWorkItemStore, queryString.ToString());
WorkItemLinkInfo[] wiTrees = wiQuery.RunLinkQuery();
WorkItem wi = GetWorkItemStore.GetWorkItem(wiTrees[1].TargetId);
return wi;
}
这种方法的问题在于它获取了所有链接的工作项,包括前置、后继、子项和父项。我知道
wiTrees[1]
是父工作项,所以我硬编码了索引。我找到了一种方法从工作项存储中获取“父级”
WorkItemTypeEnd
对象:WorkItemLinkTypeEnd linkTypEnd = GetWorkItemStore.WorkItemLinkTypes.LinkTypeEnds["Parent"];
我该从哪里开始?