TFS:查询包含特定变更集的生成



我有许多构建定义,它们是基于TFS中的单个分支执行的(例如Main)。

我想(以某种方式)查询TFS,以查找包含我提供的特定变更集编号的所有生成,并返回TFS包含的生成名称的字符串列表。任何类型的应用程序(VS扩展、CLI应用程序、winforms等)都可以。

注意:这不是"请给我代码"的请求;我愿意认真对待这件事。指向如何查询数据库或SDK的文档的任何指针,或如何查询构建的示例;只要找个地方开始寻找就会非常有帮助。谢谢

以下代码段将抓取集合的所有团队项目的所有构建定义,并检查每个构建与输入变更集编号的关联:

using System;
using System.Linq;
using Microsoft.TeamFoundation.Build.Client;
using Microsoft.TeamFoundation.Client;
using Microsoft.TeamFoundation.VersionControl.Client;
namespace FindChangesetInBuild
{
    class Program
    {
        static void Main(string[] args)
        {
            TfsTeamProjectCollection teamProjectCollection = TfsTeamProjectCollectionFactory.GetTeamProjectCollection(new Uri("http://tfs:8080/tfs/collectionName"));
            var versionControl = teamProjectCollection.GetService<VersionControlServer>();
            var buildService = (IBuildServer)teamProjectCollection.GetService(typeof(IBuildServer));
            var teamProjects = versionControl.GetAllTeamProjects(true);
            foreach (var teamProject in teamProjects)
            {
                var buildDefinitions = buildService.QueryBuildDefinitions(teamProject.Name);
                foreach (var buildDefinition in buildDefinitions)
                {
                    var builds = buildService.QueryBuilds(buildDefinition);
                    foreach (var buildDetail in builds)
                    {
                        var changesets = InformationNodeConverters.GetAssociatedChangesets(buildDetail);
                        if (changesets.Any(changesetSummary => changesetSummary.ChangesetId == Convert.ToInt32(args[0])))
                        {
                            Console.WriteLine("Changeset was build in "+buildDetail.BuildNumber);
                        }
                    }
                }
            }
        }
    }
}

不用说,这是一次暴力袭击
如果缩小buildDefinition的列表,将重点放在特定的teamProjects等,您可以进一步细化代码。在任何情况下,我都很难想象以上内容会如此有用

除了MSDN,TFS-SDK的一个很好的资源是Shai Raiten的博客
对于Build Speficic示例,请同时查看此处&这里有一些可能有趣的SO帖子。

您可以在TFS 2010中使用这个小DB查询,只需将90264替换为您的变更集id即可。

USE Tfs_Warehouse
go
SELECT BuildName 
FROM DimBuild
   INNER JOIN FactBuildChangeset
   ON DimBuild.BuildSK = FactBuildChangeset.BuildSK
WHERE FactBuildChangeset.ChangesetSK = 90264

最新更新