Как эффективно находить элементы с ожидающими изменениями с помощью Microsoft.TeamFoundationServer.Client? ⇐ C#
Как эффективно находить элементы с ожидающими изменениями с помощью Microsoft.TeamFoundationServer.Client?
Я конвертирую утилиту из интерфейса TFS SOAP в интерфейс REST. (Мы используем эту утилиту для поиска файлов, которые были извлечены слишком долго.)
Старый способ SOAP выглядит так:
var tfs = TeamFoundationServerFactory.GetServer("", new UICredentialsProvider()); tfs.EnsureAuthenticated(); var vcs = (VersionControlServer) tfs.GetService(typeof(VersionControlServer)); foreach (var pendingSet в vcs.QueryPendingSets(new[] {"$/Root"}, RecursionType.Full, null, null)) { ... Сделайте что-нибудь с pendingSet Это относительно эффективно, поскольку необходимо перебирать только те элементы, которые действительно извлечены (т. е. имеют ожидающие изменения).
Моя текущая реализация REST использует пакет NuGet Microsoft.TeamFoundationServer.Client и выглядит следующим образом:
var tfsServerUri = new Uri(""); вар учетные данные = новый VssCredentials (); // По умолчанию = текущая учетная запись пользователя. использование var Connection = new VssConnection (tfsServerUri, учетные данные); используя var projectClient = await Connection.GetClientAsync(); используя var versionControl = await Connection.GetClientAsync(); var rootProject = ждут projectClient.GetProject("Root"); var items = await versionControl.GetItemsAsync(rootProject.Id,scopePath: "$/Root", VersionControlRecursionType.Full); foreach (элемент var в элементах) { если (пункт.IsPendingChange) { ... Сделайте что-нибудь с предметом. Как видите, этот цикл просматривает КАЖДЫЙ элемент, чтобы увидеть, есть ли в нем ожидающие изменения. Это очень неэффективно.
Я просмотрел примеры на странице https://github.com/microsoft/azure-devo ... t-samples/, но не нашел примеров того, как сделать это более эффективно.
Кто-нибудь знает, как правильно это сделать с помощью интерфейсов REST?
Дополнение: похоже, что свойство IsPendingChange никогда не имеет значения true даже для извлеченных файлов. Похоже, мне тоже придется заняться этой проблемой...
Я конвертирую утилиту из интерфейса TFS SOAP в интерфейс REST. (Мы используем эту утилиту для поиска файлов, которые были извлечены слишком долго.)
Старый способ SOAP выглядит так:
var tfs = TeamFoundationServerFactory.GetServer("", new UICredentialsProvider()); tfs.EnsureAuthenticated(); var vcs = (VersionControlServer) tfs.GetService(typeof(VersionControlServer)); foreach (var pendingSet в vcs.QueryPendingSets(new[] {"$/Root"}, RecursionType.Full, null, null)) { ... Сделайте что-нибудь с pendingSet Это относительно эффективно, поскольку необходимо перебирать только те элементы, которые действительно извлечены (т. е. имеют ожидающие изменения).
Моя текущая реализация REST использует пакет NuGet Microsoft.TeamFoundationServer.Client и выглядит следующим образом:
var tfsServerUri = new Uri(""); вар учетные данные = новый VssCredentials (); // По умолчанию = текущая учетная запись пользователя. использование var Connection = new VssConnection (tfsServerUri, учетные данные); используя var projectClient = await Connection.GetClientAsync(); используя var versionControl = await Connection.GetClientAsync(); var rootProject = ждут projectClient.GetProject("Root"); var items = await versionControl.GetItemsAsync(rootProject.Id,scopePath: "$/Root", VersionControlRecursionType.Full); foreach (элемент var в элементах) { если (пункт.IsPendingChange) { ... Сделайте что-нибудь с предметом. Как видите, этот цикл просматривает КАЖДЫЙ элемент, чтобы увидеть, есть ли в нем ожидающие изменения. Это очень неэффективно.
Я просмотрел примеры на странице https://github.com/microsoft/azure-devo ... t-samples/, но не нашел примеров того, как сделать это более эффективно.
Кто-нибудь знает, как правильно это сделать с помощью интерфейсов REST?
Дополнение: похоже, что свойство IsPendingChange никогда не имеет значения true даже для извлеченных файлов. Похоже, мне тоже придется заняться этой проблемой...
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение