伪造对特定索引的数组的调用会引发异常

本文关键字:异常 调用 数组 索引 伪造 | 更新日期: 2023-09-27 17:57:09

具有以下单元测试:

public interface ITestMe
{
    object[] Values { get; }
}
[Test]
public void Test ()
{
    var sut = A.Fake<ITestMe> ();
    A.CallTo (() => sut.Values[0]).Returns (4);
    Assert.That (sut.Values[0], Is.EqualTo (4));
}

导致以下异常:

System.InvalidCastException : Unable to cast object of type 'System.Linq.Expressions.SimpleBinaryExpression' to type 'System.Linq.Expressions.InvocationExpression'.
at FakeItEasy.Expressions.CallExpressionParser.Parse(LambdaExpression callExpression)
at FakeItEasy.Configuration.FakeConfigurationManager.AssertThatMemberCanBeIntercepted(LambdaExpression callSpecification)
at FakeItEasy.Configuration.FakeConfigurationManager.CallTo(Expression1 callSpecification) at FakeItEasy.A.CallTo(Expression1 callSpecification)

或者,也许我不知道如何为索引器指定假货?

伪造对特定索引的数组的调用会引发异常

问题源于Values不是索引器的事实。它是一个返回数组的属性。

未配置的Values将返回零长度数组(因为数组不可伪造)。这就是这里发生的事情,如果它被执行,()=>sut.Values[0]就会失败(FakeItEasy 不会这样做)。

所以这里真正的收获是,由于Values是一个数组,它不是伪造的(参见什么可以伪造?),所以没有办法让 FakeItEasy 为特定的偏移量选择一个返回值。最好的办法是让Values返回您选择的数组,正如@CharlesMager所建议的那样。 例如:

var myArray = new object[100];
myArray[0] = 4;
myArray[50] = 17;
A.CallTo(() => sut.Values).Returns(myArray);