6

我有一堆项目的解决方案,其中一些还有测试项目。这些都是为Any CPU平台编译的。

在 TeamCity 中,我有一个 NUnit 2.6.4 的构建配置,我在其上指定Platform: auto (MSIL)Version: 4.0.

当我运行构建时,测试失败并显示以下消息:

NUnit error running tests in 'C:\BuildAgent\work\a58fc6cd9bf63032\JsonApi.Tests\obj\Release\JsonApi.Tests.dll' assembly
Loading assembly is compiled for v4.0.30319, MSIL
NUnit runner runtime is v4.0.30319, x64

更奇怪的是,当我刚刚关闭“首先运行最近失败的测试”(并且没有改变任何其他内容)时,我得到了以下信息:

NUnit error running tests in 'C:\BuildAgent\work\a58fc6cd9bf63032\JsonApi.Owin.Tests\obj\Release\JsonApi.Owin.Tests.dll' assembly
Loading assembly is compiled for v4.0.30319, MSIL
NUnit runner runtime is v4.0.30319, x86

请注意,在一种情况下,跑步者是 x86,而在另一种情况下是 x64。在这两种情况下,他们都没有成功加载为 MSIL 编译的程序集。

我认为这里的构建设置有些问题,但是什么?

4

3 回答 3

8

根据您提供的更详细的日志,构建失败的真正原因似乎是:

...  
System.IO.FileNotFoundException: Could not load file or assembly 'System.Web.Http, Version=5.2.3.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35 or one of its dependencies.  
The system cannot find the file specified.  
File name: 'System.Web.Http, Version=5.2.3.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35|'  

Server stack trace:  
    at System.Reflection.RuntimeAssembly.GetExportedTypes(RuntimeAssembly assembly, ObjectHandleOnStack retTypes)  
    at System.Reflection.RuntimeAssembly.GetExportedTypes()  
    at NUnit.Core.CoreExtensions.InstallAdhocExtensions(Assembly assembly)  
    at NUnit.Core.Builders.TestAssemblyBuilder.Load(String path)  
    at NUnit.Core.Builders.TestAssemblyBuilder.Build(String assemblyName, Boolean autoSuites)  
    at NUnit.Core.Builders.TestAssemblyBuilder.Build(String assemblyName, String testName, Boolean autoSuites)  
    at NUnit.Core.TestSuiteBuilder.Build(TestPackage package)  
    at NUnit.Core.SimpleTestRunner.Load(TestPackage package)  
    at NUnit.Core.ProxyTestRunner.Load(TestPackage package)  
    at NUnit.Core.ProxyTestRunner.Load(TestPackage package)  
    at NUnit.Core.RemoteTestRunner.Load(TestPackage package)  
    at System.Runtime.Remoting.Messaging.StackBuilderSink._PrivateProcessMessage(IntPtr md, Object|[|] args, Object server, Object|[|]& outArgs)  
    at System.Runtime.Remoting.Messaging.StackBuilderSink.SyncProcessMessage(IMessage msg)  
...  

而且我相信它的发生正是因为我在评论中链接的SO 线程中提到的原因,即您正在从obj文件夹运行测试,而它应该是bin。但这仍然只是一个猜测,因为您没有提供 NUnit 步骤配置。

要解决此问题,您应该明确包含单元测试的程序集所在的路径。像这样的东西:

**\bin\**\*.Tests.dll

在“列出程序集文件:”下。这样来自obj文件夹的程序集将不会得到测试,请参阅此 SO 线程

于 2015-07-16T17:30:55.317 回答
0

我对这条消息也有类似的问题

检查正确的 .NET Framework 版本和进程平台(x64、x86、MSIL)用于测试运行器设置和这台机器上涉及的程序集。

在我的情况下,原因是 NUnit 框架在代码和 Teamcity 运行器中有不同的版本。

于 2020-09-10T10:54:01.037 回答
0

在我的情况下,我得到了正确的文件夹,但是当我对 nunit3 进行编译时,TeamCity 被设置为使用 nunit2.X 进行测试。在 TeamCity 更新测试步骤解决了这个问题。

于 2019-02-27T11:27:33.440 回答