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的回调/返回方法为Func< int,int>,并且set的回调/返回方法为Action< int,int>.尝试迈克建议的,你可以为集合做这个,但有一个主要的限制:
mock.SetupSet(m => m[23] = It.IsAny<int>()) .Callback(DoSet).Verifiable();
然后使用值(23,< any>)确实调用回调DoSet.不幸的是,使用It.IsAny< int>()而不是23似乎表现为0,而不是< any>.
此外,我找不到一种方法调用SetupGet与返回,其中返回采用Func< int,int>甚至会编译.
是否可以使用Moq?
动机:我只是在玩Moq,试图用它来提供一个流畅的API来执行拦截.也就是说,给定接口I和I的实例X,自动创建模拟< I>.代理行为默认为X.
直接使用Castle DP可能更有意义,但我喜欢Moq Expression Tree语法.
解决方法 方法SetupSet采用普通委托,而不是许多其他Moq方法的Expression<...>
类型的表达式树. 出于这个原因,Moq看不到您使用过It.IsAny.相反,It.IsAny被调用(不是我们想要的),而Moq只看到它的返回值恰好是默认值(int)或0.
总结以上是内存溢出为你收集整理的c# – Moq索引属性并使用返回/回调中的索引值全部内容,希望文章能够帮你解决c# – Moq索引属性并使用返回/回调中的索引值所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)