搜索

第 93 章 Mock

download PDF

仅支持生成者

测试分布式和异步处理并不困难。MockTestDataset 端点与 Camel 测试框架协同工作,从而通过使用 企业集成模式 和 Camel 的大量组件以及强大的 Bean 集成来简化您的单元和集成测试。

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

这可让您测试各种内容,如下所示:

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

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

注意

模拟端点会无限期地保留收到的交换。
请记住,Mock 专为测试而设计。将 Mock 端点添加到路由时,发送到端点的每个 Exchange 都会在内存中存储(以允许后续验证),直到显式重置或 JVM 重启为止。如果您要发送大量卷和/或大消息,这可能会导致过量内存使用。如果您的目标是测试内联路由,请考虑在测试中使用 NotifyBuilder 或 AdviceWith,而不是将 Mock 端点直接添加到路由。有两个新选项 retainFirst 和 retainLast,可用于限制 Mock 端点在内存中保留的消息数量。

93.1. 依赖项

当在 Red Hat build of Camel Spring Boot 中使用 mock 时,请确保使用以下 Maven 依赖项来支持自动配置:

<dependency>
  <groupId>org.apache.camel.springboot</groupId>
  <artifactId>camel-mock-starter</artifactId>
</dependency>
Red Hat logoGithubRedditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

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

让开源更具包容性

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

關於紅帽

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

© 2024 Red Hat, Inc.