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