https://docs.particular.net/nservicebus/testing/有一个非常简洁的示例来说明如何测试一个简单的 Saga。不幸的是,它没有解释如何对 SqlSaga 做同样的事情 - 即。一个将状态持久化到数据库的 Saga。
鉴于这个传奇:
public class SomeFancySaga : SqlSaga<MySagaData>,
IAmStartedByMessages<ImportantCommand>
{
protected override string CorrelationPropertyName => nameof(Data.MyPrimaryKey);
protected override void ConfigureMapping(IMessagePropertyMapper mapper)
{
mapper.ConfigureMapping<ImportantCommand>(x => x.CommandId);
}
public async Task Handle(ImportantCommand command, IMessageHandlerContext context)
{
if (Data.State == MyState.ReadyForUse)
<do some stuff>
}
...
}
如果我尝试像链接中的示例那样编写测试代码,我会这样做:
// arrange
var context = new NServiceBus.Testing.TestableMessageHandlerContext();
var command = ImportantCommand.Create();
var sut = new CreateSomeFancySaga();
// act
sut.Handle(command, context);
// assert
...
对 sut.Handle() 的调用将抛出 NullReferenceException,因为Saga 属性 Data has not been initialized。
如何正确连接传奇以进行测试,以便:
- 数据初始化
- 真正需要真正的数据库连接