如何管理在开发(而非测试)环境中使用多个微服务并对其进行模拟?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何管理在开发(而非测试)环境中使用多个微服务并对其进行模拟?相关的知识,希望对你有一定的参考价值。
我正在使用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中引入仅用于开发的依赖项的想法。我的意图是使用相同的策略来集成测试和开发。
那么,有什么选择?
因此您想在本地启动微服务,例如用于手动测试,但您不想启动它依赖的所有其他微服务。
团队执行以下任一操作:
- 将本地微服务连接到共享的,已部署的微服务实例(登台环境)
- 将本地微服务连接到其他微服务的易于启动的Docker映像
- 连接到模拟某些/所有其他微服务的单个本地运行的Wiremock实例。您可以为此单独启动Wiremock,与微服务分开启动
- 编写其他微服务的最小限度的轻量级定制模拟(仅在必须执行某些业务逻辑时比Wiremock更好)
- 不连接任何东西,但是从内部API客户端返回伪值。
- 实际上是在本地启动所有其他微服务
其中哪一种最适合您取决于您的环境,以及其他微服务依赖项到底提供了什么功能。您不能期望其中的任何一个都是最适合所有团队和所有情况的银弹。
有一个名为OTDD-在线测试驱动开发]的开源项目。它将入站请求/响应及其相应的出站请求/响应记录为在线测试,然后将其用于本地开发和测试。
这个主意很好地解决了您的麻烦。在这里看看https://otdd.io。
以上是关于如何管理在开发(而非测试)环境中使用多个微服务并对其进行模拟?的主要内容,如果未能解决你的问题,请参考以下文章