无法将带有[]的索引应用于"Castle.Proxies.RangeProxy"类型的表达式

tom*_*ing 1 c# excel unit-testing moq mocking

导致此异常的原因是什么?我试图Moq用来模拟一个Microsoft.Office.Interop.Excel.Range.我想在Range里面筑巢另一个嘲笑.但是当我尝试访问嵌套异常时,会抛出异常.

例外

无法将带有[]的索引应用于"Castle.Proxies.RangeProxy"类型的表达式

[TestMethod]
public void RangeProxyIndexTest()
{
    // creating first range
    var cell1 = new Moq.Mock<Range>();
    cell1.Setup(c => c.Value2).Returns("1");

    var range1Mock = new Moq.Mock<Range>();
    range1Mock.SetupGet(r => r[1, Moq.It.IsAny<Object>()]).Returns(cell1.Object);
    var range1 = range1Mock.Object;

    // creating second range
    var cell2 = new Moq.Mock<Range>();
    cell2.Setup(c => c.Value2).Returns("2");

    var range2Mock = new Moq.Mock<Range>();
    range2Mock.SetupGet(r => r[1, Moq.It.IsAny<Object>()]).Returns(cell2.Object);
    var range2 = range2Mock.Object;

    // merging both ranges into 1
    var range3Mock = new Moq.Mock<Range>();
    range3Mock.SetupGet(r => r[1, Moq.It.IsAny<Object>()]).Returns(range1);
    range3Mock.SetupGet(r => r[2, Moq.It.IsAny<Object>()]).Returns(range2);
    var range3 = range3Mock.Object;

    // testing succeeds
    Assert.AreEqual("1", range1[1].Value2);
    Assert.AreSame(range1, range3[1]);
    Assert.AreEqual("2", range2[1].Value2);
    Assert.AreSame(range2, range3[2]);

    // exceptions are thrown here
    Assert.AreEqual("1", range3[1][1].Value2);
    Assert.AreEqual("2", range3[2][1].Value2);
}
Run Code Online (Sandbox Code Playgroud)

Old*_*Fox 6

虽然情况不同,但此异常的原因与您打开其他问题完全相同.

将您的验证部分更改为:

Assert.AreEqual("1", (range3[1] as Range)[1].Value2);
Assert.AreEqual("2", (range3[2] as Range)[1].Value2);
Run Code Online (Sandbox Code Playgroud)

有关更多信息,请阅读此答案.