• 售前

  • 售后

热门帖子
入门百科

利用长途Docker进行集成测试的情况搭建过程

[复制链接]
顺势而为47 显示全部楼层 发表于 2021-8-14 15:14:53 |阅读模式 打印 上一主题 下一主题
需求配景

团队有集成测试的需求,集成测试须要依靠一些中心件,比如mysql,rabbitmq。每个研发人员有对自己开发的那部分代码进行测试编写和运行检测的需求。
为了不互相影响,可以选择在研发本地搭建自己的依靠情况,我们渴望这些情况搭建要轻易、快速,且方便清理。
利用docker进行情况搭建

而docker,则能很好实现上述诉求。
但仅仅如许还不敷,我们还面临着以下一些题目
       
  • 本地情况搭建的繁琐。每个研发,都要在本地安装docker情况,这会导致在利用上的一些门槛和不便,以我司为例,由于有严格的网络管控,我们都是内网进行开发,无法联网。特殊windows 在安装docker时,须要联网。虽然可以想办法办理,但每个新来小搭档都要履历一些本地情况安装调试过程,实属繁琐   
  • 测试运行速度无法保证。当一个项目依靠中心件较多时,基于本地的docker也会占用大量的资源影响测试速度   
  • 多情况集成测试麻烦。由于集成测试依靠本地docker,那么这份代码在差别的情况,比如在Jenkins上打包运行时,须要在对应的情况也安装docker
总结来看,利用docker可以资助我们快速的搭建项目依靠情况,但是本地化的docker依靠,依然让我们的代码在测试时,不敷纯粹,对其各个运行情况,都有有本地docker安装的要求。
以中心化的docker server改进集成测试

而现实上,docker本身提供了远程链接模式,则使得我们可以中心化的摆设docker,然后集成测试代码以tcp链接的方式,利用docker server,进行依靠中心件搭建,测试。
Docker Server远程链接配置

以centos 为例7.6为例,讲解如何将一个docker配置成可以远程链接。
  1. /etc/docker/daemon.json
复制代码
中开启远程链接端口
  1. {"hosts": ["tcp://0.0.0.0:2375", "unix:///var/run/docker.sock"]}
复制代码
添加文件
  1. /etc/systemd/system/docker.service.d/override.conf
复制代码
,注意上述路径不存在则手动创建
  1. [Service]
  2. ExecStart=
  3. ExecStart=/usr/bin/dockerd
复制代码
       
  • 重载守护历程
    1. systemctl daemon-reload
    复制代码
       
  • 重启docker容器
    1. systemctl restart docker.service
    复制代码
Testcontainers 框架

在摆设好远程docker后,随之而来的题目是
       
  • 如何在代码中连接和利用远程docker情况   
  • 两个研发同时跑测试用例时,怎么保证他们各自启动的container 在端口上不冲突   
  • 利用完后的container,怎么清理
荣幸的是,Testcontainers框架,帮我们很好的办理了上述题目。
       
  • 它能于junit 4 ,junit 5集成,资助我们启停容器   
  • 每一次运行测试,都会启动全新的容器,暴露不一样的端口,使得两个研发同时跑测试用例时,情况互不干扰   
  • 它利用testcontainers/ryuk在指定延迟后,清理不再利用的container   
  • 上述这统统对利用者都是透明的
Testcontainers 同spring boot集成

更进一步的,游戏公司Playtika提供了Testcontainers 同spring boot整合的测试框架
  1. https://github.com/Playtika/testcontainers-spring-boot
复制代码
,使得Spring Boot或Spring cloud生态的应用在编写集成测试时,更方便
情况变量依靠

利用Testcontainers 或 playtika的testcontainers-spring-boot进行远程docker链接时,都不须要在本地安装docker客户端。但须要进行相干情况变量配置,使得代码可以知道远程docker的地址。该地址的配置有如下几种方式
       
  • 方式1,体系情况变量配置,在当前体系配置情况变量
    1. DOCKER_HOST=tcp://remote_docker_server_ip:2375
    复制代码
       
  • 方式2,直接在java测试代码中,容器构造前,通过代码
    1. System.setProperty("DOCKER_HOST","tcp://remote_docker_server_ip:2375")
    复制代码
    指定情况变量   
  • 方式3,假如集成测试利用maven failsafe插件,则在插件上配置情况变量

以command line远程利用和管理docker

上述测试代码不须要安装docker 客户端。但倘若我们须要以命令行的方式,管理docker,则可以安装一些docker客户端,来跟远程docker通信。固然上述的Testcontainers 相称于客户端的一种。
差别利用体系的客户端步调安装方式见: https://gist.github.com/kekru/4e6d49b4290a4eebc7b597c07eaf61f2
参考资料
https://www.testcontainers.org/
https://gist.github.com/styblope/dc55e0ad2a9848f2cc3307d4819d819f
https://github.com/Playtika/testcontainers-spring-boot
https://gist.github.com/kekru/4e6d49b4290a4eebc7b597c07eaf61f2
到此这篇关于利用远程Docker进行集成测试的文章就先容到这了,更多相干Docker集成测试内容请搜索草根技术分享以前的文章或继承欣赏下面的相干文章渴望各人以后多多支持草根技术分享!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作