通常,我都在Setup
和Verify
中写相同的参数表达式。有没有办法参考它们?
我写的是
var mock = new Moq<IFoo>();
mock.Setup(m => m.MyMethod(It.Is.Any<string>());
...
mock.Verify(m => m.MyMethod(It.Is.Any<string>()), Times.Once);
然后我想到Setup
和Verify
共享相同的参数,因此应该/应该将其移至通用引用中,如下所示:
var MyMethodCall = {WHAT SHOUD BE HERE?};
var mock = new Moq<IFoo>();
mock.Setup(m => MyMethodCall);
...
mock.Verify(m => MyMethodCall, Times.Once);
答案 0 :(得分:4)
您可以创建一个保存表达式的变量,以便您可以重用它:
Expression<Action<IFoo>> expression = x => x.MyMethod(It.Is.Any<string>());
var mock = new Moq<IFoo>();
mock.Setup(expression);
...
mock.Verify(expression, Times.Once);
答案 1 :(得分:1)
在这种情况下,可以使用Verifiable
,则根本不需要在Verify
中指定参数。它将验证是否已调用特定的可验证Setup
。
var mock = new Moq<IFoo>();
mock.Setup(m => m.MyMethod(It.Is.Any<string>()).Verifiable();
...
mock.Verify();
IMO Verifiable
是更好的选择,因为Verify(Expression<>)
不适用于安装程序,而是内部调用。解释如下:
public class Example
{
public bool IsValid { get; set; }
}
public interface IExample
{
bool Do(Example e);
}
// arrange
Expression<Func<IExample, bool>> expr = m => m.Do(It.Is<Example>(x => x.IsValid));
var mock = new Mock<IExample>();
mock.Setup(expr).Verifiable();
// act
var example = new Example {IsValid = true};
mock.Object.Do(example);
example.IsValid = false;
// assert
mock.Verify(expr, Times.Once);
结局是什么?测试将失败,因为Verify
将在对象更改后对表达式求值。如果您使用的是Verify
,则在调用时将捕获该调用。但是,这只是一个展示柜,不应经常发生:)