如何管理在开发(而非测试)环境中使用多个微服务并对其进行模拟?

问题描述 投票:6回答:2

我正在使用Spring Boot 1.5.9,我们有一个与另一个微服务连接的微服务。

用于集成测试和开发(开发人员计算机),我想模拟/存根对另一个微服务的其余调用。对于单元/集成测试,已经多次回答了这个问题:WireMock,MockBean和MockRestServiceServer是很好的工具。但是for development我正在尝试找出最佳方法。

为什么?启动实际微服务所依赖的每个微服务是一个问题。因此,我们的想法是使微服务独立并启动,而无需在开发人员的机器上或其他地方运行任何其他服务器。因此,一个简单的`mvn spring-boot run'就足以启动我的微服务并开始工作,而无需担心其他微服务。

所以,我的问题是:在开发中建议的模拟/存根休息方法是什么?在这种情况下,Wiremock也是一种很好的方法?

我的项目

我在src/main/java/resources/中有两个配置文件:“默认”(application.properties,用于另一个环境)和“ dev”(application-dev.properties,用于开发)。

在我的测试(src/test/java/resources/)中,我只有一个application.properties,这是application-dev.properties的基本副本。

我已经尝试使用Wiremock进行集成测试,并且效果很好。但是我也不想将其用于开发,因为我不太喜欢在JAR中引入仅用于开发的依赖项的想法。我的意图是使用相同的策略来集成测试和开发。

那么,有什么选择?

java spring rest mocking development-environment
2个回答
5
投票

因此您想在本地启动微服务,例如用于手动测试,但您不想启动它依赖的所有其他微服务。

团队执行以下任一操作:

  • 将本地微服务连接到共享的,已部署的微服务实例(登台环境)
  • 将本地微服务连接到其他微服务的易于启动的Docker映像
  • 连接到模拟某些/所有其他微服务的单个本地运行的Wiremock实例。您可以为此单独启动Wiremock,与微服务分开启动
  • 编写其他微服务的最小限度的轻量级定制模拟(仅在必须执行某些业务逻辑时比Wiremock更好)
  • 不连接任何东西,但是从内部API客户端返回伪值。
  • 实际上是在本地启动所有其他微服务

其中哪一种最适合您取决于您​​的环境,以及其他微服务依赖项到底提供了什么功能。您不能期望其中的任何一个都是最适合所有团队和所有情况的银弹。


-5
投票

有一个名为OTDD-在线测试驱动开发]的开源项目。它将入站请求/响应及其相应的出站请求/响应记录为在线测试,然后将其用于本地开发和测试。

这个主意很好地解决了您的麻烦。在这里看看https://otdd.io

© www.soinside.com 2019 - 2024. All rights reserved.