第 33 章 Mock


仅支持制作者

测试分布式和异步处理非常困难。MockTestingDataset 端点与 Camel 测试框架配合良好,使用 企业集成模式 和 Camel 的大型组件与强大的 Bean 集成来简化您的单元和集成测试。

Mock 组件提供了一个强大的声明性测试机制,与 jMock 类似,它允许在测试开始前在任意 Mock 端点上创建声明性预期。然后运行该测试,这通常会在一个或多个端点上触发消息,最后,可以在测试案例中断言预期,以确保系统按预期工作。

这可让您测试各种内容,例如:

  • 每个端点上接收了正确的消息数量,
  • 正确的有效负载(按正确的顺序)收到正确的有效负载,
  • 消息按顺序到达端点,使用一些表达式创建顺序测试功能,
  • 消息到达匹配某种形式的 Predicate,比如特定标头具有某些值,或者消息与某些 predicate 匹配,例如通过评估 XPathXQuery 表达式。
注意

还有一个 Test 端点,它是一个 Mock 端点,它使用第二个端点提供预期消息正文列表,并自动设置 Mock endpoint assertions。换句话说,它是一个 Mock 端点,它会自动从文件或 数据库中 的一些示例消息设置断言,例如:

注意

模拟端点可无限期地保留接收的 Exchange。
请记住,Mock 是用于测试的。当您将 Mock 端点添加到路由时,发送到端点的每个 Exchange 将存储(以允许稍后验证),直到重启明确重置或 JVM。如果您要发送大量卷和/或大型消息,则可能导致过量内存使用。如果您的目标是在内联测试可部署的路由,请考虑在测试中使用 NotifyBuilder 或 AdviceWith,而不是直接向路由添加 Mock 端点。有两个新选项保持First,而 retainLast 可用于限制 Mock 端点保留在内存中的消息数量。

33.1. URI 格式

mock:someName[?options]

其中 someName 可以是唯一标识端点的任意字符串。

Red Hat logoGithubRedditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

通过我们的产品和服务,以及可以信赖的内容,帮助红帽用户创新并实现他们的目标。

让开源更具包容性

红帽致力于替换我们的代码、文档和 Web 属性中存在问题的语言。欲了解更多详情,请参阅红帽博客.

關於紅帽

我们提供强化的解决方案,使企业能够更轻松地跨平台和环境(从核心数据中心到网络边缘)工作。

© 2024 Red Hat, Inc.