4

次の公開コードをテストしようとしています(クラスとプロパティは例として調整されています-目的):

public void PublishMessages(List<SomeDummyClass> shareRegistrationResult)
{    
    var failedMessages = shareRegistrationResult
                                .Where(c => !c.WasRegistered)
                                .Select(c => CreateNotRegisteredMessageInstance(c.String1, c.String2)).ToArray();
    _bus.Publish(failedMessages);
}

private IMyMessage CreateNotRegisteredMessageInstance(string string1, string string2)
{
    return _bus.CreateInstance<IMyMessage>(message =>
                                    {
                                        message.String1 = string1;
                                        message.String2 = string2;
                                    });
}

テストコード(ダミーメッセージに一致するように変更)

NServiceBus.Testing.Test.Handler(bus => new Publisher()
     .ExpectPublish<IMyMessage>(message => message.String1 == "Hello" && message.String2 == "World")
     .ExpectPublish<IMyMessage>(message => message.String1 == "Foo" && message.String2 == "Bar");

これは、failedMessages配列にメッセージが1つしかない場合は問題なく機能しますが、配列に複数のメッセージがある場合は次のエラーで失敗します。

Rhino.Mocks.Exceptions.ExpectationViolationException : IBus.Publish(callback method: <>c__DisplayClass1c`1.<ExpectPublish>b__1b); Expected #1, Actual #0.
IBus.Publish(callback method: <>c__DisplayClass1c`1.<ExpectPublish>b__1b); Expected #1, Actual #0.

1つの公開で複数のメッセージをテストするときにExpectPublishテスト(または他の何か)を使用する方法についてのアイデアはありますか?

4

1 に答える 1

0

これはバグです-https://github.com/NServiceBus/NServiceBus/issues/489

于 2012-06-20T19:07:35.997 に答える