Docker与Web自动化测试:一键创建Selenium Grid集群

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: Docker的容器技术的优秀特性,例如秒级启动、应用隔离、良好的可移植性等,可以在DevOps中大显身手,并推动持续集成,持续交付等理念落地。今天我们就将结合Selenium Grid来介绍Docker在自动化测试中的使用场景。

Docker的容器技术的优秀特性,例如秒级启动、应用隔离、良好的可移植性等,可以在DevOps中大显身手,并推动持续集成,持续交付等理念落地。今天我们就将结合Selenium Grid来介绍Docker在自动化测试中的使用场景。

Selenium Grid 简介

Selenium 是针对Web应用的自动化测试框架和工具集合,支持多种浏览器和编程语言。Selenium的测试用例直接运行在浏览器中,并模拟用户的操作。

Selenium Grid是一个分布式Web测试工具,可以将测试透明地分发到多个主机上,并行地执行。Selenium Grid架构中包含两个主要角色:Hub是中心点控制节点,而Node是Selenium的工作节点,它们注册到Hub上,并会操作浏览器执行由Hub下发的自动测试用例。

14583886947794

以传统的方式部署分布式Selenium Grid集群有一定的技术难度。而且一个浏览器在操作系统上只能安装一个版本且只能有一个运行实例。比如为了针对不同版本的Chrome进行测试,需要将指定版本的Chrome浏览器安装到不同物理机或虚拟机上,这样要耗费大量时间和机器成本来准备测试环境。

在去年Selenium Conf 2015上,Marek Jastrzebaki介绍并演示了利用Docker技术来部署Selenium Grid的示例,可以优雅地解决上述问题。

让我们也尝试一下Docker带给我们不同的测试体验吧 :-)

利用阿里容器服务搭建自动测试环境

我们将在阿里容器服务上面搭建Selenium Grid的示例,并运行自动化测试用例。

下面的DockerCompose模板描述了一个Selenium Grid集群的部署方式:它会创建一组容器,其中包含1个Selenium Hub容器,3个Firefox Node和3个Chrome Node。这里所有的Docker镜像可以从 https://github.com/denverdino/docker-selenium 获得,它们在Selenium官方镜像基础上,修复了节点和Hub容器在重新启动后的一些问题。这些修改稍后会提交社区。

hub:
  image: registry.aliyuncs.com/denverdino/selenium-hub
  ports:
    - 4444:4444
  labels:
    aliyun.routing.port_4444: http://selenium/
firefox:
  image: registry.aliyuncs.com/denverdino/selenium-node-firefox
  links:
    - hub
  labels: 
    aliyun.scale: "3"
chrome:
  image: registry.aliyuncs.com/denverdino/selenium-node-chrome
  links:
    - hub
  labels: 
    aliyun.scale: "3"

注:你可以利用Docker Compose在本地Docker环境上测试上述脚本,但是需要手工伸缩节点。

在阿里云容器服务上部署完成之后,很快我们就可以看到容器应用所包含的所有容器都已经启动成功。

14583894550228

我们可以通过点击hub服务来获得Grid Console的访问信息。

14583980964870

点击访问端点后,在浏览器中可以看到,Selenium Grid的控制台里已经有6个节点就绪,其中3个是Firefox节点,3个是Chrome节点。

14583981369820

下面我们来运行Web测试。我提供了一个非常简单的测试示例:利用Python的Selenium bindings和nose并行测试框架,它会并行地调用Firefox和Chrome在百度和云栖社区上搜索和docker相关的内容。

为了简化使用,我也提供Docker镜像来调用Selenium测试脚本。详见 https://github.com/denverdino/docker-selenium/tree/master/test

我们选择之前Selenium测试应用,点击配置变更后将docker-compose模板更新为如下内容。它会添加test service来调用hub分发执行测试用例。

hub:
  image: registry.aliyuncs.com/denverdino/selenium-hub
  ports:
    - 4444:4444
  labels:
    aliyun.routing.port_4444: http://selenium/
firefox:
  image: registry.aliyuncs.com/denverdino/selenium-node-firefox
  links:
    - hub
  labels: 
    aliyun.scale: "3"
chrome:
  image: registry.aliyuncs.com/denverdino/selenium-node-chrome
  links:
    - hub
  labels: 
    aliyun.scale: "3"
test:
  image: registry.aliyuncs.com/denverdino/selenium-test
  links:
    - hub
    - firefox
    - chrome

14584321377231
注意:修改应用配置后,需要更新应用版本便于追踪。

变更配置完成后过几十秒钟,我们发现“test”服务已经停止运行,在日志中我们可以看到所有自动化测试已经执行完毕。

14584322685740

总结

通过Docker可以大大简化Selenium Grid分布式测试的部署,削减机器资源消耗,减少配置虚拟机所花的时间,极大的提高了测试效率。

Docker和测试领域还可以有很多结合点:比如利用Docker镜像良好的可移植性,我们可以在开发、测试、生产环节中保证一致性;利用容器编排,我们可以低成本、快速的构建集成测试环境,来对应用进行有效验证,等等。

以后我们还会介绍如何利用阿里云容器服务把DevOps过程串联起来,让开发者简单从一个简单的git commit开始,自动化地触发并执行完整的应用构建、测试、和更新流程。

相关实践学习
巧用云服务器ECS制作节日贺卡
本场景带您体验如何在一台CentOS 7操作系统的ECS实例上,通过搭建web服务器,上传源码到web容器,制作节日贺卡网页。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
目录
相关文章
|
3月前
|
网络安全 Docker 容器
|
3月前
|
安全 Docker 容器
|
3月前
|
网络安全 Docker 容器
|
3月前
|
网络安全 数据安全/隐私保护 Docker
|
1月前
|
Web App开发 IDE JavaScript
Selenium IDE:Web自动化测试的得力助手
Selenium IDE:Web自动化测试的利器。作为开源工具,Selenium IDE支持录制与回放用户操作,适用于Chrome、Firefox等多浏览器,简化了测试流程,提升了效率,降低了自动化测试的门槛。它还支持导出多种编程语言的脚本,便于测试集成与复用。
90 19
Selenium IDE:Web自动化测试的得力助手
|
1月前
|
Web App开发 IDE 测试技术
Selenium:强大的 Web 自动化测试工具
Selenium 是一款强大的 Web 自动化测试工具,包括 Selenium IDE、WebDriver 和 Grid 三大组件,支持多种编程语言和跨平台操作。它能有效提高测试效率,解决跨浏览器兼容性问题,进行性能测试和数据驱动测试,尽管存在学习曲线较陡、不稳定等缺点,但其优势明显,是自动化测试领域的首选工具。
189 17
Selenium:强大的 Web 自动化测试工具
|
1月前
|
Prometheus 监控 Cloud Native
如何使用Prometheus监控Docker Swarm集群的资源使用情况?
还可以根据实际需求进行进一步的配置和优化,如设置告警规则,当资源使用超出阈值时及时发出警报。通过这些步骤,能够有效地使用 Prometheus 对 Docker Swarm 集群的资源进行监控和管理。
68 8
|
1月前
|
Prometheus 监控 Cloud Native
如何监控Docker Swarm集群的性能?
如何监控Docker Swarm集群的性能?
122 8
|
1月前
|
监控 Docker 容器
Docker Swarm集群的扩展与缩容策略,涵盖其意义、方法、步骤及注意事项
本文深入探讨了Docker Swarm集群的扩展与缩容策略,涵盖其意义、方法、步骤及注意事项,旨在帮助用户高效管理集群资源,适应业务变化,确保服务稳定性和资源优化。
58 6
|
2月前
|
API Docker 容器
【赵渝强老师】构建Docker Swarm集群
本文介绍了如何使用三台虚拟主机构建Docker Swarm集群。首先在master节点上初始化集群,然后通过特定命令将node1和node2作为worker节点加入集群。最后,在master节点上查看集群的节点信息,确认集群构建成功。文中还提供了相关图片和视频教程,帮助读者更好地理解和操作。