单元测试事件中心EventProcessor

时间:2015-08-12 03:43:04

标签: c# unit-testing azure-eventhub

我目前正在学习Microsoft事件中心,并且我遵循示例代码here。我更改了ProcessEventsAsync(PartitionContext context, IEnumerable<EventData> events)方法,以便在获得EventData之后,将其存储到数据库中。现在,我想使用单元测试来测试我的代码。在测试类中,我设置了一个发送器,并在初始化方法中将数据发送到事件中心,该部分工作正常。然后我创建了一个新的测试方法来测试接收器端。代码如下所示:

[TestMethod]
public void TestProcessEventsAsync()
{
    //Initialize the receiver, and run it
    Receiver receiver = new Receiver();
    Receiver r = new Receiver(eventHubName, connectionString);
    r.MessageProcessingWithPartitionDistribution();

    //check if the data is stored in the database
    ...
}

在这里,我只是创建一个新的接收器实例,并使用它来处理发送到事件中心的数据。我只向事件中心发送了三个对象,其中两个使用相同的分区。测试失败,输出显示并非所有分区都已初始化,这意味着接收器在处理完所有数据之前已停止。

我猜测,由于MessageProcessingWithPartitionDistribution()方法将任务划分为多个线程,因此单元测试不会以这种方式工作。所以我的问题是如何使用单元测试来测试这个MessageProcessingWithPartitionDistribution()方法?

感谢任何帮助!

1 个答案:

答案 0 :(得分:1)

要确保EventProcessor在您在测试中检入数据库之前干净地关闭,您应该致电:

r.UnregisterEventProcessor();

这应该确保处理所有未决消息并且EventProcessor执行受控关闭。