19

好的,这是我遇到的问题的完整描述:

我正在尝试使用NUnit ExtensionMethods,但是每当我使用 TestDriven.Net 运行包含其中一种扩展方法的测试时,或者如果我只是尝试使用测试运行程序 GUI(Icarus 或 NUnit)加载程序集,我就会得到 FileNotFoundException。

用头撞墙并进一步挖掘,我想我知道出了什么问题。提示反射器,是的,我可以看到 NUnit.Framework>ExtensionMethods.dll 引用了

nunit.framework, Version=2.4.6.0, Culture=neutral, PublicKeyToken=96d09a1eb7f44a77

我当前包含的 nunit 版本是

nunit.framework, Version=2.4.8.0, Culture=neutral, PublicKeyToken=96d09a1eb7f44a77

现在我以前从未使用过程序集重定向,但似乎只需添加一个带有以下行的 App.Config 就很简单了:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <runtime>
        <assemblyBinding  xmlns="urn:schemas-microsoft-com:asm.v1">
            <dependentAssembly>
                <assemblyIdentity
                    name="nunit.framework.dll"
                    publicKeyToken="96d09a1eb7f44a77" />
                <bindingRedirect oldVersion="2.4.6.0" newVersion="2.4.8.0" />
            </dependentAssembly>
        </assemblyBinding>
    </runtime>
</configuration>

我的理解是调用 2.4.6 版本(这台机器上不存在)应该自动重定向到 2.4.8 版本。

但是这不起作用,我怀疑(但尚未确认)这是因为测试运行器不会自动读取 app.config 文件。

所以我的问题如下:

  1. 我对问题的诊断是否正确?

  2. 程序集重定向是适当的解决方案吗?我做得对吗?

  3. 我如何让它与测试运行器一起工作?

4

1 回答 1

18

如果您将配置设置放在正确的 .config 文件中,这应该可以工作。哪一个取决于您用于运行测试的环境,但 NUnit 和 TestDriven.NET 都应该支持使用testassembly .dll.config。
至于这是适当的解决方案,我会说是的。唯一的另一种可能性是使用发布者策略文件,但您需要用于编译 NUnit 的私钥。

于 2009-01-21T16:01:47.023 回答