0

当我尝试使用GetDefinitionAsync()AzureFunctions 时,出现以下错误,无法从 VSTS 获取数据。

执行函数时出现异常:Functions.VSTSWebhookCSharp。Microsoft.Azure.WebJobs.Script:出现一个或多个错误。mscorlib:无法加载文件或程序集“Microsoft.TeamFoundation.Core.WebApi,Version=14.0.0.0,Culture=neutral,PublicKeyToken=b03f5f7f11d50a3a”或其依赖项之一。该系统找不到指定的文件。

我检查了 .dll 是否由 AzureFunctions 还原,但它存在于“ D:\home\data\Functions\packages\nuget\Microsoft.TeamFoundationServer.Client\14.89.0\lib\net45\Microsoft.TeamFoundation.Core.WebApi .dll

您对此错误有任何想法吗?

我尝试的代码如下。(它通过 ASP.NET Webhook 成功运行。)

#r "Newtonsoft.Json"
#r "System.Configuration"

using System;
using System.Collections.Generic;
using System.Configuration;
using System.Diagnostics;
using System.IO;
using System.Linq;
using System.Net;
using System.Net.Http;
using System.Text;
using System.Text.RegularExpressions;
using System.Threading.Tasks;
using Microsoft.TeamFoundation.Build.WebApi;
using Microsoft.VisualStudio.Services.Common;
using Newtonsoft.Json;
using Newtonsoft.Json.Linq;

public static async Task<object> Run(HttpRequestMessage req, TraceWriter log)
{
    string jsonContent = await req.Content.ReadAsStringAsync();

    // Deserialize Json
    var jsonObject = JsonConvert.DeserializeObject<VSTSWebHook>(jsonContent);

    // From ApplicationSettings
    var vstsUser = ConfigurationManager.AppSettings["VstsUser"];
    var vstsPassword = ConfigurationManager.AppSettings["VstsPassword"];

    // Create VSTS Connection from Json Value
    var project = new Guid(jsonObject.resource.definition.project.id);
    var definitionId = jsonObject.resource.definition.id;
    var result = jsonObject.resource.result;
    var buildId = jsonObject.resource.id;
    var build = new BuildHttpClient(new Uri("https://<YOUR TENANT>.VisualStudio.com/DefaultCollection/"), new VssBasicCredential(vstsUser, vstsPassword));

    // Exception will happen at here.   
    // Obrain definition from VSTS
    var buildDefinition = await build.GetDefinitionAsync(project, definitionId);

    return req.CreateResponse(HttpStatusCode.OK, new {
        body = $"Test Complete.",
    });
}

public class VSTSWebHook
{
    public string subscriptionId { get; set; }
    public int notificationId { get; set; }
    public string id { get; set; }
    public string eventType { get; set; }
    public string publisherId { get; set; }
    public Message message { get; set; }
    public Detailedmessage detailedMessage { get; set; }
    public Resource resource { get; set; }
    public string resourceVersion { get; set; }
    public Resourcecontainers resourceContainers { get; set; }
    public DateTime createdDate { get; set; }
}

public class Message
{
    public string text { get; set; }
    public string html { get; set; }
    public string markdown { get; set; }
}

public class Detailedmessage
{
    public string text { get; set; }
    public string html { get; set; }
    public string markdown { get; set; }
}

public class Resource
{
    public int id { get; set; }
    public string status { get; set; }
    public string result { get; set; }
    public DateTime queueTime { get; set; }
    public DateTime startTime { get; set; }
    public DateTime finishTime { get; set; }
    public string url { get; set; }
    public Definition definition { get; set; }
    public string uri { get; set; }
    public string sourceBranch { get; set; }
    public string sourceVersion { get; set; }
    public Queue queue { get; set; }
    public string priority { get; set; }
    public string reason { get; set; }
    public Requestedfor requestedFor { get; set; }
    public Requestedby requestedBy { get; set; }
    public DateTime lastChangedDate { get; set; }
    public Lastchangedby lastChangedBy { get; set; }
    public Orchestrationplan orchestrationPlan { get; set; }
    public Logs logs { get; set; }
    public Repository repository { get; set; }
}

public class Definition
{
    public string type { get; set; }
    public int revision { get; set; }
    public int id { get; set; }
    public string name { get; set; }
    public string url { get; set; }
    public Project project { get; set; }
}

public class Project
{
    public string id { get; set; }
    public string name { get; set; }
    public string url { get; set; }
    public string state { get; set; }
}

public class Queue
{
    public object pool { get; set; }
    public int id { get; set; }
    public string name { get; set; }
}

public class Requestedfor
{
    public string id { get; set; }
    public string displayName { get; set; }
    public string uniqueName { get; set; }
    public string url { get; set; }
    public string imageUrl { get; set; }
}

public class Requestedby
{
    public string id { get; set; }
    public string displayName { get; set; }
    public string uniqueName { get; set; }
    public string url { get; set; }
    public string imageUrl { get; set; }
    public bool isContainer { get; set; }
}

public class Lastchangedby
{
    public string id { get; set; }
    public string displayName { get; set; }
    public string uniqueName { get; set; }
    public string url { get; set; }
    public string imageUrl { get; set; }
    public bool isContainer { get; set; }
}

public class Orchestrationplan
{
    public string planId { get; set; }
}

public class Logs
{
    public int id { get; set; }
    public string type { get; set; }
    public string url { get; set; }
}

public class Repository
{
    public string id { get; set; }
    public string type { get; set; }
    public object clean { get; set; }
    public bool checkoutSubmodules { get; set; }
}

public class Resourcecontainers
{
    public Collection collection { get; set; }
    public Account account { get; set; }
    public Project1 project { get; set; }
}

public class Collection
{
    public string id { get; set; }
}

public class Account
{
    public string id { get; set; }
}

public class Project1
{
    public string id { get; set; }
}

更新

这是我的 project.json。

{
 "frameworks": {
   "net46":{
     "dependencies": {
       "Microsoft.TeamFoundationServer.Client" : "14.89.0",
       "Microsoft.VisualStudio.Services.Client" : "14.89.0"
     }
   }
 }
}

看起来像是GetDefinitionAsync()BuildHttpClienseBase 类中包含的方法。所以问题是为什么要加载dll?

var t = typeof(Microsoft.TeamFoundation.Build.WebApi.BuildHttpClientBase);
var member = t.GetMembers(
    BindingFlags.Public | BindingFlags.NonPublic |
    BindingFlags.Instance | BindingFlags.Static |
    BindingFlags.DeclaredOnly
);

结果是

Method : CreateArtifactAsync
Method : CreateArtifactAsync
Method : CreateArtifactAsync
Method : GetArtifactAsync
Method : GetArtifactAsync
Method : GetArtifactAsync
Method : GetArtifactContentZipAsync
Method : GetArtifactContentZipAsync
Method : GetArtifactContentZipAsync
Method : GetArtifactsAsync
Method : GetArtifactsAsync
Method : GetArtifactsAsync
Method : GetBadgeAsync
Method : DeleteBuildAsync
Method : DeleteBuildAsync
Method : DeleteBuildAsync
Method : GetBuildAsync
Method : GetBuildAsync
Method : GetBuildAsync
Method : GetBuildsAsync
Method : GetBuildsAsync
Method : GetBuildsAsync
Method : QueueBuildAsync
Method : QueueBuildAsync
Method : QueueBuildAsync
Method : UpdateBuildAsync
Method : UpdateBuildAsync
Method : UpdateBuildAsync
Method : GetBuildCommitsAsync
Method : GetBuildCommitsAsync
Method : GetChangesBetweenBuildsAsync
Method : GetChangesBetweenBuildsAsync
Method : GetBuildControllerAsync
Method : GetBuildControllersAsync
Method : CreateDefinitionAsync
Method : CreateDefinitionAsync
Method : CreateDefinitionAsync
Method : DeleteDefinitionAsync
Method : DeleteDefinitionAsync
Method : DeleteDefinitionAsync
Method : GetDefinitionAsync
Method : GetDefinitionAsync
Method : GetDefinitionAsync
Method : GetDefinitionsAsync
Method : GetDefinitionsAsync
Method : GetDefinitionsAsync
Method : UpdateDefinitionAsync
Method : UpdateDefinitionAsync
Method : UpdateDefinitionAsync
Method : GetBuildDeploymentsAsync
Method : GetBuildDeploymentsAsync
Method : GetBuildLogAsync
Method : GetBuildLogAsync
Method : GetBuildLogsAsync
Method : GetBuildLogsAsync
Method : GetBuildLogsZipAsync
Method : GetBuildLogsZipAsync
Method : GetBuildOptionDefinitionsAsync
Method : CreateQueueAsync
Method : DeleteQueueAsync
Method : GetAgentPoolQueueAsync
Method : GetQueuesAsync
Method : GetResourceUsageAsync
Method : GetDefinitionRevisionsAsync
Method : GetDefinitionRevisionsAsync
Method : GetBuildSettingsAsync
Method : UpdateBuildSettingsAsync
Method : AddBuildTagAsync
Method : AddBuildTagAsync
Method : AddBuildTagsAsync
Method : AddBuildTagsAsync
Method : DeleteBuildTagAsync
Method : DeleteBuildTagAsync
Method : GetBuildTagsAsync
Method : GetBuildTagsAsync
Method : GetTagsAsync
Method : GetTagsAsync
Method : DeleteTemplateAsync
Method : DeleteTemplateAsync
Method : GetTemplateAsync
Method : GetTemplateAsync
Method : GetTemplatesAsync
Method : GetTemplatesAsync
Method : SaveTemplateAsync
Method : SaveTemplateAsync
Method : GetBuildTimelineAsync
Method : GetBuildTimelineAsync
Method : GetBuildWorkItemsRefsAsync
Method : GetBuildWorkItemsRefsAsync
Method : GetBuildWorkItemsRefsFromCommitsAsync
Method : GetBuildWorkItemsRefsFromCommitsAsync
Method : GetWorkItemsBetweenBuildsAsync
Method : GetWorkItemsBetweenBuildsAsync
Constructor : .ctor
Constructor : .ctor
Constructor : .ctor
Constructor : .ctor
Constructor : .ctor
NestedType : <GetArtifactContentZipAsync>d__11
NestedType : <GetArtifactContentZipAsync>d__12
NestedType : <GetArtifactContentZipAsync>d__13
NestedType : <GetBuildLogAsync>d__56
NestedType : <GetBuildLogAsync>d__57
NestedType : <GetBuildLogsZipAsync>d__60
NestedType : <GetBuildLogsZipAsync>d__61
4

1 回答 1

1

它通过 AzureFunctions 0.2 解决。

成功调用方法没有问题。

于 2016-05-10T18:40:01.680 回答