0

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

如何正确连接传奇以进行测试,以便:

  1. 数据初始化
  2. 真正需要真正的数据库连接
4

1 回答 1

2

我们有一个相关的代码示例更详细地显示了单元测试:https ://docs.particular.net/samples/unit-testing/ 。SagaTests.cs这包括对 saga ( )的几个测试。

您可以以此为起点,通过以下方式修改 saga 测试:

  1. 添加NServiceBus.Persistence.Sql包。
  2. 将策略传奇修改DiscountPolicy为继承自SqlSaga而不是Saga.
  3. 解决编译错误(添加缺少的方法和属性,您可以将它们保留为空,以及删除ConfigureHowToFindSaga方法)。

我希望这会有所帮助,但如果有任何遗漏或您的方案无法以这种方式进行测试,请告诉我。

于 2018-06-15T12:30:14.900 回答