Получение описания проекта TFS
Мне нужно собрать информацию из существующей установки TFS 2012, и администратор поместил некоторые полезные данные в описание командного проекта.
Я думал, что будет легко получить его, но я не могу видеть эти данные, представленные ни одним из свойств Microsoft.TeamFoundation.WorkItemTracking.Client.Project или Microsoft.TeamFoundation.Server.ProjectInfo. Я думал о запросе к базам данных Collection, но таблицы tbl_projects и tbl_project_properties не содержат данных описания.
2 ответа
Я полагаю, что класс Microsoft.TeamFoundation.Framework.Client.CatalogResource имеет искомое свойство Description. Приведенный ниже код подключается к серверу конфигурации TFS, а затем записывает коллекции и имена и описания командных проектов.
private static void WriteOutTeamProjects()
{
// Connect to Team Foundation Server
// Server is the name of the server that is running the application tier for Team Foundation.
// Port is the port that Team Foundation uses. The default port is 8080.
// VDir is the virtual path to the Team Foundation application. The default path is tfs.
Uri tfsUri = new Uri("http://vsalm:8080/tfs/");
TfsConfigurationServer configurationServer = TfsConfigurationServerFactory.GetConfigurationServer(tfsUri);
// Get the catalog of team project collections
ReadOnlyCollection<CatalogNode> collectionNodes = configurationServer.CatalogNode.QueryChildren(new[] { CatalogResourceTypes.ProjectCollection }, false, CatalogQueryOptions.None);
// List the team project collections
foreach (CatalogNode collectionNode in collectionNodes)
{
// Use the InstanceId property to get the team project collection
Guid collectionId = new Guid(collectionNode.Resource.Properties["InstanceId"]);
TfsTeamProjectCollection teamProjectCollection = configurationServer.GetTeamProjectCollection(collectionId);
// Print the name of the team project collection
Console.WriteLine("Collection: " + teamProjectCollection.Name);
// Get a catalog of team projects for the collection
ReadOnlyCollection<CatalogNode> projectNodes = collectionNode.QueryChildren(new[] { CatalogResourceTypes.TeamProject }, false, CatalogQueryOptions.None);
// List the team projects in the collection
foreach (CatalogNode projectNode in projectNodes)
{
Console.WriteLine(" Team Project: " + projectNode.Resource.DisplayName);
Console.WriteLine(" Description: " + projectNode.Resource.Description);
}
}
Console.WriteLine("Press any key to finish...");
Console.ReadKey();
}
Этот запрос в базе данных конфигурации дает те же данные.
SELECT [DisplayName] AS ProjectName, [Description] AS ProjectDescription
FROM [Tfs_Configuration].[dbo].[tbl_CatalogResource]
WHERE ResourceType = (
SELECT [Identifier]
FROM [Tfs_Configuration].[dbo].[tbl_CatalogResourceType] WHERE [DisplayName] = 'Team Project')
ORDER BY 1