我正在尝试使用 NSubstitute 或其他模拟框架和 MSTest (Visual Studio 2010) 模拟 Excel 电子表格。我不确定是否有比这更好的方法——而且这对于测试来说不太有效:
这是一个示例(这是目前的所有原型代码,并且不是很干净):
int[] lowerBounds = { 1, 1 };
int[] lengths = { 2, 2 };
//Initialize a 1-based array like Excel does:
object[,] values = (object[,])Array.CreateInstance(typeof(object), lengths, lowerBounds);
values[1,1] = "hello";
values[2,1] = "world";
//Mock the UsedRange.Value2 property
sheet.UsedRange.Value2.Returns(values);
//Test:
GetSetting(sheet, "hello").Should().Be("world"); //FluentAssertions
到目前为止,一切顺利:如果 GetSetting 方法是,则通过在同一个项目中作为我的测试。但是,当 GetSetting 位于我的 VSTO Excel-Addin 项目中时,它会失败,并在 GetSetting 函数的第一行出现以下错误:
System.MissingMethodException: Error: Missing method 'instance object [MyExcel.AddIn] Microsoft.Office.Interop.Excel.Range::get_Value2()' from class 'Castle.Proxies.RangeProxy'.
作为参考,GetSetting 从工作表的 A 列中获取一个值,并返回 B 列中的值。
public static string GetSetting(Excel.Worksheet sheet, string settingName) {
object[,] value = sheet.UsedRange.Value2 as object[,];
for (int row = 1; row <= value.GetLength(1); row++) {
if (value[1, row].ToString() == settingName)
return value[2, row].ToString();
}
return "";
}
最后一个有趣的部分是,如果我重新定义方法的签名,如下所示:
公共静态字符串 GetSetting(dynamic工作表,字符串设置名称)
它适用于 VSTO 项目。
那么到底发生了什么事,做这样的事情的最佳方法是什么?
Thanks!