Fitnesse Slim runner 无法加载 .net 5 程序集:从文件中提取清单导入时出错 (hr = 0x80131018)

问题描述

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.exeRunnerW.exe(及其依赖项)的 .Net Core 版本,并使用它们代替旧的 SLIM .Net 运行程序(如果您正在迁移) . FusionLog 对 .Net Core 完全没有任何作用,因此如果有任何日志记录,那么您就知道该进程没有运行 .Net Core。

3:如果您从 GitHub 获得 FitSharp 项目并且链接到项目而不是使用 NuGet,则删除后期构建操作以复制文件。而是转到您的测试项目 Dependencies -> Projects -> fit 打开属性 (F4) 并设置选项 Reference Output AssemblyCopy Local 和 {{1}是的。对 FitSharp 和 Runner 项目执行相同操作。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...