44.14. 使用 arrival 时间进行测试
Mock 端点将消息的 arrival 时间存储为交换上的属性
Date time = exchange.getProperty(Exchange.RECEIVED_TIMESTAMP, Date.class);
您可以使用这些信息知道消息何时到达模拟。但是,它还为了解之前和下一个消息之间的时间间隔提供基础。您可以使用此选项在 Mock 端点上设置使用 arrives
DSL 的预期。
例如,在下一个操作前,第一个消息应该在 0-2 秒之间到达:
mock.message(0).arrives().noLaterThan(2).seconds().beforeNext();
您还可以将其定义为第二条消息(基于 0 索引)在上一个消息后没有超过 0-2 秒:
mock.message(1).arrives().noLaterThan(2).seconds().afterPrevious();
您还可以使用在 之间设置较低绑定。例如,假设它应该在 1-4 秒之间:
mock.message(1).arrives().between(1, 4).seconds().afterPrevious();
您还可以对所有信息设置预期,例如,指出它们间的差距应该最多 1 秒:
mock.allMessages().arrives().noLaterThan(1).seconds().beforeNext();
注意
上面的示例中,
使用 秒
作为时间单位,但 Camel 也提供 毫秒
和 分钟
。