gpt4 book ai didi

c# - 如何用最小起订量模拟 Microsoft.Office.Interop.Excel.Range?

转载 作者:太空狗 更新时间:2023-10-29 21:40:39 24 4
gpt4 key购买 nike

我想模拟 Microsoft.Office.Interop.Excel.Range(和其他 Microsoft.Office.Interop.Excel 接口(interface))来对我的应用程序进行单元测试。我在 C# 中使用带有 .NET 4 的 Moq 4.0.10827。

在我的单元测试中,我尝试如下设置模拟的行为:

        var range = new Mock<Microsoft.Office.Interop.Excel.Range>();
range.Setup(r => r.get_Value(1)).Returns("Something");

var classBeingTested = new MyClass(range.Object);

在进行单元测试的代码中,我按如下方式使用范围:

    public MyClass(Range range)
{
var value = range[1].ToString();
}

当测试运行时,它会产生以下异常:

        Error: Missing method 'instance object [My.Example.Implementation.MyClass] Microsoft.Office.Interop.Excel.Range::get__Default(object,object)' from class 'Castle.Proxies.RangeProxy'.

我怎样才能成功实现这个模拟?我意识到使用 https://stackoverflow.com/a/9486226/1548950 等模式隔离 Excel Interop 功能是一个潜在的解决方案;但是,如果能够从 Microsoft.Office.Interop.Excel 接口(interface)创建模拟,我会更高兴。

编辑:有关此问题的更多详细信息

好吧,这很奇怪。我创建了一个项目来测试 jimmy_keen 的建议。有用。但是,当我使用相同的建议来测试我遇到问题的项目时,它抛出以下异常:

Error: Missing method 'instance object [My.Example.Implementation.MyClass] Microsoft.Office.Interop.Excel.Range::get__Default(object,object)' from class 'Castle.Proxies.RangeProxy'.

由于 jimmy_keen 的建议在其他项目上运行良好,我开始怀疑我正在测试代码的项目有问题。所以,我创建了一个测试详细说明问题的解决方案:http://www7.zippyshare.com/v/70834394/file.html

问题的根源似乎是该项目包含另一个类(未进行单元测试),其代码基本如下:

using Microsoft.Office.Interop.Excel;
namespace Project
{
public class UnTestedClass
{
public UnTestedClass(Worksheet sheet)
{
var foo = sheet.Range["Description"].Column;
}
}
}

我不明白为什么会导致这个问题,因为我根本没有在单元测试中使用 UnTestedClass。我是否遗漏了一些关于如何使用 Moq 的信息,或者我是否偶然发现了错误?

最佳答案

您的代码访问索引器,这就是您需要模拟的内容:

var range = new Mock<Microsoft.Office.Interop.Excel.Range>();
range.Setup(r => r[1, It.IsAny<object>()]).Returns("something");

请注意 Range indexer 实际上有两个参数——因此是 It.IsAny<object>()调用中的约束。

关于c# - 如何用最小起订量模拟 Microsoft.Office.Interop.Excel.Range?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11633042/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com