我想要起订量一个具有索引的属性,并且我希望能够在回调中使用索引值,就像您可以在回调中使用起订量方法的方法参数一样。可能最容易用一个例子来演示:
public interface IToMoq
{
int Add(int x, int y);
int this[int x] { get; set; }
}
Action<int, int> DoSet = (int x, int y) =>
{
Console.WriteLine("setting this[{0}] = {1}", x, y);
throw new Exception("Do I ever get called?");
};
var mock = new Mock<IToMoq>(MockBehavior.Strict);
//This works perfectly
mock.Setup(m => m.Add(It.IsAny<int>(), It.IsAny<int>()))
.Returns<int, int>((a, b) => a + b);
//This compiles, but my callback never seems to be called
mock.SetupSet(m => m[It.IsAny<int>()] = It.IsAny<int>())
.Callback(DoSet);
var obj = mock.Object;
Console.WriteLine("Add(3,4) => {0}", obj.Add(3, 4)); //Works perfectly
obj[1] = 2; //Does not throw, why?
编辑:为了澄清,我想要回调/返回方法get
to be Func<int,int>
,以及回调/返回方法set
to be Action<int,int>
。尝试一下迈克的建议,你可以这样做set
,但有一个主要限制:
mock.SetupSet(m => m[23] = It.IsAny<int>())
.Callback(DoSet).Verifiable();
回调DoSet
然后确实用值调用(23,<any>)
。不幸的是,使用It.IsAny<int>()
代替23
似乎表现得像0
, 而不是<any>
.
另外,我找不到调用方式SetupGet
with Returns
where Returns
需要一个Func<int,int>
甚至可以编译。
可以使用起订量吗?
动机:我只是在玩 Moq,尝试使用它来提供流畅的 API 来执行拦截。也就是说,给定一个接口I
和一个实例X
of I
,自动创建一个Mock<I>
代理行为默认为X
.
直接使用 Castle DP 可能更有意义,但我喜欢 Moq 表达式树语法。