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

How manage working with multiple microservices and mocking them in a development (not test) environment?

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

对于集成测试和开发(开发人员计算机),我想mock/stub对另一个微服务进行的其余调用。对于 unit/integration 测试,这个问题已经回答了很多次:WireMock、MockBean 和 MockRestServiceServer 都是很好的工具。但是为了发展我正在尝试找出最好的方法。

为什么?启动实际微服务所依赖的每个微服务都是一个问题。因此,我们的想法是让微服务独立并在开发人员的机器或其他地方没有任何额外的服务器 运行ning 的情况下启动。因此,一个简单的“mvn spring-boot 运行”就足以启动我的微服务并正常工作,而无需担心其他微服务。

所以,我的问题是:mock/stub rest 在开发中调用的推荐方法是什么?在这种情况下,Wiremock 也是一种好方法吗?

我的项目

我在 src/main/java/resources/ 中有两个配置文件:'default'(application.properties,用于另一个环境)和 'dev'(应用程序-dev.properties , 用于开发).

在我的测试中 (src/test/java/resources/) 我只有一个 application.properties,那是应用程序的基本副本 - dev.properties.

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

那么,有哪些选择?

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

团队执行以下操作之一:

  • 将本地微服务连接到共享的、已部署的微服务实例(暂存环境)
  • 将本地微服务连接到其他微服务的易于启动的docker映像
  • 连接到一个本地 运行 模仿 some/all 其他微服务的 wiremock 实例。您可以为此独立启动 wiremock,与您的微服务分开
  • 为其他微服务编写一个最小的轻量级自定义模拟(如果必须执行一些业务逻辑,只比 wiremock 更好)
  • 不连接任何东西,但 return 来自内部 API 客户端的虚拟值。
  • 实际上在本地启动所有其他微服务

哪一个最适合您取决于您​​的环境,以及其他微服务依赖项提供的功能。您不能指望其中任何一个成为适用于所有团队和所有情况的灵丹妙药。