0

在 Fitnesse 中运行测试给出:

无法完成测试:fitnesse.slim.SlimError:错误 SLiM 服务器在可以读取标头消息之前死亡。

当使用 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 文件并指定一个运行时,但我不确定,它可能只是一个兔子洞,因为我们似乎需要在这里混合框架?

4

1 回答 1

0

一些最终让我启动并运行的事情:

1:不要引用可执行文件(以 结尾的文件.exe),而是引用.dll。无论如何编译,尝试将 .exe 文件作为程序集加载总是会抛出System.BadImageFormatException.

2:从 NuGet 包中获取 .Net Core 版本Runner.exeRunnerW.exe(及其依赖项),并使用这些版本而不是旧的 SLIM .Net 运行程序(如果您正在迁移)。FusionLog.Net Core 完全没有任何作用,所以如果有任何日志记录,那么您就知道该进程没有运行 .Net Core。

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

于 2021-06-09T15:38:23.717 回答