TFS未加载自定义程序集

TFS未加载自定义程序集,tfs,process,build,assemblies,Tfs,Process,Build,Assemblies,我在尝试让生成控制器/代理从生成过程模板中使用的引用获取自定义程序集时遇到问题 我在多个博客上广泛阅读了有关此问题的内容,但不幸的是,我无法解决此问题: ] 我可以证实以下几点: TFS 2012无更新Visual Studio 2013,更新1(用于创建 活动和升级生成过程模板) 具有多个代理的一个构建控制器 TFS程序集已签入源代码管理并位于源代码管理中 重新启动服务时,在生成控制器中设置了正确的路径: 遵循这些博客中使用的指导原则时,自定义活动在模板中正确解析: 我可以在构建过程

我在尝试让生成控制器/代理从生成过程模板中使用的引用获取自定义程序集时遇到问题

我在多个博客上广泛阅读了有关此问题的内容,但不幸的是,我无法解决此问题:

]

我可以证实以下几点:

  • TFS 2012无更新Visual Studio 2013,更新1(用于创建 活动和升级生成过程模板)

  • 具有多个代理的一个构建控制器

  • TFS程序集已签入源代码管理并位于源代码管理中

  • 重新启动服务时,在生成控制器中设置了正确的路径:

    遵循这些博客中使用的指导原则时,自定义活动在模板中正确解析:

    我可以在构建过程模板的XAML中查看引用,它看起来很好,没有验证错误,并且我的代码活动似乎得到了正确实现

    下面的代码:

    using System;
    using System.Collections;
    using System.Collections.Generic;
    using System.ComponentModel;
    using System.IO;
    using System.Linq;
    using System.Reflection;
    using System.Text;
    using System.Activities;
    using System.Text.RegularExpressions;
    using Microsoft.TeamFoundation.Build.Client;
    using Microsoft.TeamFoundation.VersionControl.Client;
    
    namespace FireWatch.TFS
    {
        [BuildActivity(HostEnvironmentOption.Agent)]
        public sealed class AssemblyUpdater : CodeActivity
        {
            #region Static Methods
            #endregion   
    
            #region Property Variables
            #endregion
    
            #region Constants and Read-Onlys
            private const string ASSEMBLY_VERSION_REG_EX = @"\(""\d+\.\d+\.\d+\.\d+""\)";
            private const string ATTRIBUTE_REG_EX = "AssemblyVersion";
            #endregion
    
            #region Accessors
    
            [RequiredArgument]
            public InArgument<int> Major { get; set; }
            [RequiredArgument]
            public InArgument<int> Minor { get; set; }
            [RequiredArgument]
            public InArgument<int> Build { get; set; }
            [RequiredArgument]
            public InArgument<Workspace> Workspace { get; set; }
    
            #endregion
    
            #region Encapsulation
    
            private void UpdateAssemblyInfo(IEnumerable<string> assemblyInfos, int major, int minor, int build)
            {
                foreach (string myAssemblyInfo in assemblyInfos)
                {
                    string myFileText = File.Exists(myAssemblyInfo) ? File.ReadAllText(myAssemblyInfo) : string.Empty;
    
                    if (myFileText != string.Empty)
                    {
                        Regex myRegex = new Regex(ATTRIBUTE_REG_EX + ASSEMBLY_VERSION_REG_EX);
                        Match myMatch = myRegex.Match(myFileText);
    
                        if (myMatch.Success)
                        {
                            string myVersionNumber = myMatch.Value.Substring(ATTRIBUTE_REG_EX.Length + 2,
                                                     myMatch.Value.Length - ATTRIBUTE_REG_EX.Length - 4);
    
                            Version myCurrentVersion = new Version(myVersionNumber);
                            Version myNewVersion = new Version(major, minor, build, (myCurrentVersion.Revision + 1));
    
                            string myUpdatedAssemblyText = myRegex.Replace(myFileText, ATTRIBUTE_REG_EX + "(\"" + myNewVersion + "\")");
    
                            File.WriteAllText(myAssemblyInfo, myUpdatedAssemblyText);
                        }
                    }
                }
            }
    
            private void CheckOut(Workspace workspace, IList<string> assemblyInfos)
            {
                if (workspace != null && assemblyInfos != null && assemblyInfos.Any())
                {
                    workspace.PendEdit(assemblyInfos.ToArray());
                }
            }
    
            private IEnumerable<string> GetRelevantAssemblyInfos(Workspace workspace)
            {
                IList<string> myReturn = new List<string>();
    
                PendingChange[] myPendingChanges = workspace.GetPendingChanges();
    
                foreach (PendingChange myPendingChange in myPendingChanges)
                {
                    string myPath = AssemblyInfoPresent(myPendingChange);
    
                    if (!string.IsNullOrEmpty(myPath))
                    {
                        myReturn.Add(myPath);
                    }
                }
    
                return myReturn;
            }
    
            private string AssemblyInfoPresent(PendingChange pendingChange)
            {
                string myReturn = string.Empty;
    
                if (pendingChange != null)
                {
                    string myParentDirectory = pendingChange.LocalItem;
                    string myParentLevelAssemblyInfo = myParentDirectory + @"\AssemblyInfo.cs";
    
                    string myPropertiesDirectory = pendingChange.LocalItem + @"\Properties";
                    string myPropertiesLevelAssemblyInfo = myParentDirectory + @"\Properties\AssemblyInfo.cs";
    
                    if (Directory.Exists(myPropertiesDirectory) && File.Exists(myPropertiesLevelAssemblyInfo))
                    {
                        myReturn = myPropertiesLevelAssemblyInfo;
                    }
                    else if (Directory.Exists(myParentDirectory) && File.Exists(myParentLevelAssemblyInfo))
                    {
                        myReturn = myParentLevelAssemblyInfo;
                    }
                }
    
                return myReturn;
            }
    
            #endregion
    
            #region CodeActivity Members
    
            protected override void Execute(CodeActivityContext context)
            {
                int myMajor = context.GetValue(this.Major);
                int myMinor = context.GetValue(this.Minor);
                int myBuild = context.GetValue(this.Build);
                Workspace myWorkspace = context.GetValue(this.Workspace);
    
                IList<string> myAssemblyInfos = GetRelevantAssemblyInfos(myWorkspace).Distinct().ToList();
    
                if (myAssemblyInfos.Any())
                {
                    CheckOut(myWorkspace, myAssemblyInfos);
                    UpdateAssemblyInfo(myAssemblyInfos, myMajor, myMinor, myBuild);
                }
            }
    
            #endregion
        }
    }
    
    使用系统;
    使用系统集合;
    使用System.Collections.Generic;
    使用系统组件模型;
    使用System.IO;
    使用System.Linq;
    运用系统反思;
    使用系统文本;
    使用系统活动;
    使用System.Text.RegularExpressions;
    使用Microsoft.TeamFoundation.Build.Client;
    使用Microsoft.TeamFoundation.VersionControl.Client;
    命名空间FireWatch.TFS
    {
    [BuildActivity(HostenEnvironmentOption.Agent)]
    公共密封类AssemblyUpdater:CodeActivity
    {
    #区域静态方法
    #端区
    #区域属性变量
    #端区
    #区域常数和只读
    私有常量字符串程序集\u VERSION\u REG\u EX=@“\(“\d+\。\d+\。\d+\。\d+\)”;
    私有常量字符串属性\u REG\u EX=“AssemblyVersion”;
    #端区
    #区域存取器
    [必需参数]
    公共非语法主语{get;set;}
    [必需参数]
    公共非语法小调{get;set;}
    [必需参数]
    公共InArgument生成{get;set;}
    [必需参数]
    公共InArgument工作区{get;set;}
    #端区
    #区域封装
    私有void UpdateAssemblyInfo(IEnumerable assemblyInfo、int-major、int-minor、int-build)
    {
    foreach(assemblyInfos中的字符串myAssemblyInfo)
    {
    字符串myFileText=File.Exists(myAssemblyInfo)?File.ReadAllText(myAssemblyInfo):string.Empty;
    if(myFileText!=string.Empty)
    {
    Regex-myRegex=新的Regex(属性\u REG\u EX+程序集\u版本\u REG\u EX);
    Match myMatch=myRegex.Match(myFileText);
    如果(myMatch.Success)
    {
    字符串myVersionNumber=myMatch.Value.Substring(属性_REG_EX.Length+2,
    myMatch.Value.Length-属性_REG_EX.Length-4);
    版本myCurrentVersion=新版本(myVersionNumber);
    版本myNewVersion=新版本(主要版本、次要版本、内部版本,(myCurrentVersion.Revision+1));
    字符串MyUpdateAssemblyText=myRegex.Replace(myFileText,属性为“\”“+myNewVersion+”);
    WriteAllText(myAssemblyInfo、myUpdatedAssemblyText);
    }
    }
    }
    }
    私有void签出(工作区,IList assemblyInfos)
    {
    if(workspace!=null&&assemblyInfos!=null&&assemblyInfos.Any())
    {
    PendEdit(assemblyInfos.ToArray());
    }
    }
    私有IEnumerable GetRelevantAssemblyInfos(工作区)
    {
    IList myReturn=新列表();
    PendingChanges[]myPendingChanges=workspace.GetPendingChanges();
    foreach(挂起更改我的挂起更改我的挂起更改中的更改)
    {
    字符串myPath=AssemblyInfoPresent(myPendingChange);
    如果(!string.IsNullOrEmpty(myPath))
    {
    myReturn.Add(myPath);
    }
    }
    返回我的返回;
    }
    私有字符串汇编InfoPresent(PendingChange PendingChange)
    {
    string myReturn=string.Empty;
    如果(pendingChange!=null)
    {
    字符串myParentDirectory=pendingChange.LocalItem;
    字符串myParentLevelAssemblyInfo=myParentDirectory+@“\AssemblyInfo.cs”;
    字符串myPropertiesDirectory=pendingChange.LocaleItem+@“\Properties”;
    字符串myPropertiesLevelAssemblyInfo=myParentDirectory+@“\Properties\AssemblyInfo.cs”;
    if(Directory.Exists(myPropertiesDirectory)和&File.Exists(myPropertiesLevelAssemblyInfo))
    {
    myReturn=myPropertiesLevelAssemblyInfo;
    }
    else if(Directory.Exists(myParentDirectory)和&File.Exists(myParentLevelAssemblyInfo))
    {
    myReturn=myParentLevelAssemblyInfo;
    }
    }
    返回我的返回;
    }
    #端区
    #区域代码活动成员
    受保护的覆盖无效执行(CodeActivityContext上下文)
    {
    int myMajor=context.GetValue(this.Major);
    int myMinor=context.GetValue(this.Minor);
    int myBuild=context.GetValue(this.Build);
    Workspace myWorkspace=context.GetValue(this.Workspace);
    IList myAssemblyInfos=GetRelevantAssemblyInfos(myWorkspace).Distinct().ToList();
    if(myAssemblyInfos.Any())
    {
    签出(myWorkspace、myAssemblyInfos);
    UpdateAssemblyInfo(myAssemblyInfos、myMajor、myMinor、myBuild);
    }