Len*_*art 4 c# unit-testing moq autofixture mvvm-light
我有一个派生类,它通过属性注入获取一个对象并在该对象的信使上注册:
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()
{
//..
}
}
Run Code Online (Sandbox Code Playgroud)
基本上,我想设置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
Run Code Online (Sandbox Code Playgroud)
VerifySet()成功,并传入正确的对象(通过调试检查),并且信使实例相同。但是Verify方法调用失败了,我真的不明白为什么。
我不太确定我必须使用的设置方法(设置?SetupSet?另一个?) fooMock
删除您对
fooMock.SetupAllProperties();
Run Code Online (Sandbox Code Playgroud)
这会导致 Mock 覆盖该属性,并且永远不会在 setter 中调用您的 Register 方法。
上一行导致永远不会运行的代码(因为它被自定义实现覆盖)
public override IBar Bar
{
get { return _bar; }
set
{
_bar = value;
_bar?.Messenger.Register<MyMessage>(this, m => SomeMethod());
}
}
Run Code Online (Sandbox Code Playgroud)
因此,您永远不会订阅 Messenger 上的任何消息。
以下为我工作:
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
Run Code Online (Sandbox Code Playgroud)
在发送消息以告诉 Moq 注册调用之前,您可能需要做的一件事是:
fooMock.Setup(x => x.SomeMethod()).Verifiable();
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
427 次 |
| 最近记录: |