我有一个派生类,它通过属性注入获取对象并在该对象的信使上注册:
public class Foo : AbsFoo
{
private IBar bar;
public override IBar Bar
{
get {return bar;}
set
{
bar = value
if(bar != null)
{
bar.Messenger.Register<MyMessage>(this, m => SomeMethod());
}
}
}
public override void SomeMethod()
{
//..
}
}
基本上,我想设置Bar
,发送消息,并验证是否已调用SomeMethod()
。
我的测试看起来像这样:
var fixture = new Fixture();
fixture.Customize(new AutoConfiguredMoqCustomization());
var messenger = new Messenger();
var barFixture = fixture.Create<IBar>();
barFixture.Messenger = messenger
var fooMock = new Mock<Foo> {CallBase = true};
fooMock.SetupAllProperties();
fooMock.Object.Bar = barFixture;
fooMock.VerifySet(s=> s.Bar = It.IsAny<IBar>(),Times.AtLeastOnce()); // Success
messenger.Send(new MyMessage());
fooMock.Verify(c => c.SomeMethod(), Times.Once); // Fails
VerifySet()
成功,并传入正确的对象(通过调试检查),并且信使实例是相同的。但是方法调用上的Verify
失败了,我真的不明白为什么。
我不太确定我必须使用的设置方法(Setup?SetupSet?Another?)fooMock
答案 0 :(得分:4)
移除您对
的电话 fooMock.SetupAllProperties();
这会导致Mock覆盖该属性,并且永远不会在setter中调用Register方法。
以上行导致永远不会运行的代码(因为它被覆盖到自定义实现)
public override IBar Bar
{
get { return _bar; }
set
{
_bar = value;
_bar?.Messenger.Register<MyMessage>(this, m => SomeMethod());
}
}
因此,您永远不会订阅信使上的任何消息。
以下为我工作:
var messenger = new Messenger();
var bar = new Mock<Foo.IBar>();
bar.Setup(x => x.Messenger).Returns(messenger);
var fooMock = new Mock<Foo> { CallBase = true };
//fooMock.SetupAllProperties();
fooMock.Object.Bar = bar.Object;
fooMock.VerifySet(s => s.Bar = It.IsAny<Foo.IBar>(), Times.AtLeastOnce()); // Success
messenger.Send(new Foo.MyMessage());
fooMock.Verify(c => c.SomeMethod(), Times.Once); // Works
在发送消息告诉Moq注册呼叫之前,您可能需要做的一件事是:
fooMock.Setup(x => x.SomeMethod()).Verifiable();