问题描述
在 fitnesse 中运行测试给出:
无法完成测试:fitnesse.slim.SlimError:SLiM 服务器错误 在 Header Message 可以被读取之前死亡。
使用 Slim RunnerW.exe 调试我的测试时出现异常:
System.BadImageFormatException
:无法加载文件或程序集
'file:///c:\path\assemby.exe' 或其依赖项之一。模块
预计包含程序集清单。
我使用 ProcessExplorer 检查 RunnerW.exe 是否在 64 位模式下运行。我的代码是用“任何 cpu”编译的,与另一个工作项目的唯一区别是它是一个使用 fitsharp 2.8.2.1 NuGet 包的 .net 5(核心)项目。
启用 FusionLog 后,很明显它无法加载我的主要测试程序集。这是日志的一部分:
LOG: This bind starts in LoadFrom load context.
WRN: Native image will not be probed in LoadFrom context. Native image will only be probed in default load context,like with Assembly.Load().
LOG: No application configuration file found.
LOG: Using host configuration file:
LOG: Using machine configuration file from C:\Windows\Microsoft.NET\Framework64\v4.0.30319\config\machine.config.
LOG: Attempting download of new URL file:///C:/path/assembly.exe.
LOG: Assembly download was successful. Attempting setup of file: C:\path\assembly.exe
LOG: Entering run-from-source setup phase.
ERR: Error extracting manifest import from file (hr = 0x80131018).
ERR: Run-from-source setup phase Failed with hr = 0x80131018.
ERR: Failed to complete setup of assembly (hr = 0x80131018). Probing terminated.
我认为它正在尝试将 .Net 5 程序集加载到 .Net 4 进程中?
任何想法如何解决这个问题?我想添加一个 app.config 文件并指定一个运行时,但我不确定,这可能只是一个兔子洞,因为我们似乎需要在这里混合框架?
解决方法
最终让我开始工作的一些事情:
1:不要引用可执行文件(以 .exe
结尾的文件),而是引用 .dll
。不管它是如何编译的,尝试将 .exe 文件作为程序集加载总是会抛出一个 System.BadImageFormatException
。
2:从 NuGet 包中提取 Runner.exe
和 RunnerW.exe
(及其依赖项)的 .Net Core 版本,并使用它们代替旧的 SLIM .Net 运行程序(如果您正在迁移) . FusionLog
对 .Net Core 完全没有任何作用,因此如果有任何日志记录,那么您就知道该进程没有运行 .Net Core。
3:如果您从 GitHub 获得 FitSharp 项目并且链接到项目而不是使用 NuGet,则删除后期构建操作以复制文件。而是转到您的测试项目 Dependencies
-> Projects
-> fit
打开属性 (F4) 并设置选项 Reference Output Assembly
、Copy Local
和 {{1}是的。对 FitSharp 和 Runner 项目执行相同操作。