基于docker部署的Selenium Grid分布式自动化测试

这篇具有很好参考价值的文章主要介绍了基于docker部署的Selenium Grid分布式自动化测试。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

01、什么是Selenium Grid

Selenium Grid是Selenium套件的一部分,它专门用于并行运行多个测试用例在不同的浏览器、操作系统和机器上。

Selenium Grid有两个版本——老版本Grid 1和新版本Grid 2。我们只对新版本做介绍,因为Selenium团队已经逐渐遗弃老版本了。

Selenium Grid 主要使用 master-slaves (or hub-nodes) 理念 --一个 master/hub 和多个基于master/hub注册的子节点 slaves/nodes。当我们在master上基于不同的浏览器/系统运行测试用例时,master将会分发给适当的node运行。

基于docker部署的Selenium Grid分布式自动化测试,自动化测试,软件测试,软件测试工程师,selenium,测试工具,软件测试,程序人生,自动化测试,职场发展,功能测试
什么时候用Selenium Grid

同时在不同的浏览器、操作系统和机器上运行测试。最大程度用于兼容性测试

减少运行时间

02、怎样启动Selenium Grid

启动Selenium Grid的三种方式,一种直接用命令行,另一种用JSON配置文件,最后一种docker启动

1、命令行启动

将会使用2台机器,一台运行hub另一台运行node,为了方便描述,将运行hub的机器命名为“Machine H”(IP:192.168.1.100),运行node的机器命名为“Machine N”(IP:192.168.1.101)

Step 1

1、配置Java环境

2、已安装需要运行的浏览器

3、下载浏览器driver,放到和selenium server相同的路径下 ,否则在启动node时要加参数,不然启动不了浏览器(java -Dwebdriver.chrome.driver=“C:\your path\chromedriver.exe” -jar selenium-server-standalone-3.141.59.jar -role node -hubhttp://192.168.1.100:5566/grid/register/,可切换浏览器)

基于docker部署的Selenium Grid分布式自动化测试,自动化测试,软件测试,软件测试工程师,selenium,测试工具,软件测试,程序人生,自动化测试,职场发展,功能测试

4、下载selenium server,将selenium-server-standalone-X.XX.jar分别放在“Machine H”和“Machine N”上(自定义路径)
基于docker部署的Selenium Grid分布式自动化测试,自动化测试,软件测试,软件测试工程师,selenium,测试工具,软件测试,程序人生,自动化测试,职场发展,功能测试

Step 2

在机器“Machine H”上打开命令行,到selenium server所在的路径,运行:java -jar selenium-server-standalone-3.141.59.jar -role hub -port 5566,成功启动你会看到:
基于docker部署的Selenium Grid分布式自动化测试,自动化测试,软件测试,软件测试工程师,selenium,测试工具,软件测试,程序人生,自动化测试,职场发展,功能测试

或者直接在机器“Machine H”上的浏览器(“Machine N”则需要将IP修改为“Machine H”的)打开:http://localhost:5566/grid/console ,将会看到:
基于docker部署的Selenium Grid分布式自动化测试,自动化测试,软件测试,软件测试工程师,selenium,测试工具,软件测试,程序人生,自动化测试,职场发展,功能测试

在机器“Machine N”上打开命令行,到selenium server所在的路径,运行:java -jar selenium-server-standalone-3.141.59.jar -role node -hub http://192.168.1.100:5566/grid/register/ -port 5577,成功启动你会看到:

刷新:http://localhost:5566/grid/console ,将会看到:

基于docker部署的Selenium Grid分布式自动化测试,自动化测试,软件测试,软件测试工程师,selenium,测试工具,软件测试,程序人生,自动化测试,职场发展,功能测试
刷新:http://localhost:5566/grid/console ,将会看到:
基于docker部署的Selenium Grid分布式自动化测试,自动化测试,软件测试,软件测试工程师,selenium,测试工具,软件测试,程序人生,自动化测试,职场发展,功能测试

Step 3

运行测试脚本,将会看到在机器“Machine N”上打开了Chrome浏览器,并运行了测试用例:
基于docker部署的Selenium Grid分布式自动化测试,自动化测试,软件测试,软件测试工程师,selenium,测试工具,软件测试,程序人生,自动化测试,职场发展,功能测试

from selenium import webdriver



ds = {'platform': 'ANY',

      'browserName': "chrome",

      'version': '',

      'javascriptEnabled': True

      }

dr = webdriver.Remote('http://192.168.1.101:5577/wd/hub', desired_capabilities=ds)

dr.get("https://www.baidu.com")

print dr.name

2、Json配置文件启动

Step 1

1、创建hub的Json配置文件

代码如下:

{

  "port": 4444,

  "newSessionWaitTimeout": -1,

  "servlets" : [],

  "withoutServlets": [],

  "custom": {},

  "capabilityMatcher": "org.openqa.grid.internal.utils.DefaultCapabilityMatcher",

  "registry": "org.openqa.grid.internal.DefaultGridRegistry",

  "throwOnCapabilityNotPresent": true,

  "cleanUpCycle": 5000,

  "role": "hub",

  "debug": false,

  "browserTimeout": 0,

  "timeout": 1800

}

将上述代码保存为hub_config.json文件,放在“Machine H”上和selenium server相同的路径下。

2、创建nodes的 Json配置文件

代码如下:

{

  "capabilities":

  [

    {

      "browserName": "firefox",

      "marionette": true,

      "maxInstances": 5,

      "seleniumProtocol": "WebDriver"

    },

    {

      "browserName": "chrome",

      "maxInstances": 5,

      "seleniumProtocol": "WebDriver"

    },

    {

      "browserName": "internet explorer",

      "platform": "WINDOWS",

      "maxInstances": 1,

      "seleniumProtocol": "WebDriver"

    },

    {

      "browserName": "safari",

      "technologyPreview": false,

      "platform": "MAC",

      "maxInstances": 1,

      "seleniumProtocol": "WebDriver"

    }

  ],

  "proxy": "org.openqa.grid.selenium.proxy.DefaultRemoteProxy",

  "maxSession": 5,

  "port": -1,

  "register": true,

  "registerCycle": 5000,

  "hub": "http://192.168.1.100:4444",

  "nodeStatusCheckTimeout": 5000,

  "nodePolling": 5000,

  "role": "node",

  "unregisterIfStillDownAfter": 60000,

  "downPollingLimit": 2,

  "debug": false,

  "servlets" : [],

  "withoutServlets": [],

  "custom": {}

}

保存为文件(注意将hub对应的值改为机器“Machine H”的IP),放在“Machine N”上和selenium server相同的路径下。(当多个node时需将该文件放在多个node机器上或者同一个机器上启动多个node)

Step 2

hub机器上命令行运行:java -jar selenium-server-standalone-3.141.59.jar -role hub -hubConfig hub_config.json

node机器上命令行运行:java -jar selenium-server-standalone-3.141.59.jar -role node -nodeConfig node_config.json

运行之前的验证方法和脚本查看是否正确

(1、2)方式启动的挑战(不易启动和维护):

每个node需要下载和配置依赖

java 进程占内存

出现问题时需手动启动

不易维护

扩展性差

3、docker启动

docker上已经有selenium官方的Selenium Grid镜像,只有你已经安装了docker,即可使用。

启动hub:

docker run -d -p 4444:4444 --name selenium-hub selenium/hub

启动node(Chrome&&Firefox):

docker run -d --link selenium-hub:hub selenium/node-firefox

运行命令将会下载内置镜像文件(包括java、Chrome、Firefox、selenium-server-standalone-XXX.jar 等运行selenium所需的环境);此时你可以访问:http://localhost:4444/grid/console
基于docker部署的Selenium Grid分布式自动化测试,自动化测试,软件测试,软件测试工程师,selenium,测试工具,软件测试,程序人生,自动化测试,职场发展,功能测试

如果需要多个Chrome node则继续运行这个命令:docker run -d --link selenium-hub:hub selenium/node-chrome,刷新则看到多了一个Chrome实例。

通过运行命令:docker ps,显示正在运行的容器
基于docker部署的Selenium Grid分布式自动化测试,自动化测试,软件测试,软件测试工程师,selenium,测试工具,软件测试,程序人生,自动化测试,职场发展,功能测试

关闭docker-grid的命令:docker stop $(docker ps -a -q), docker rm $(docker ps -a -q)

docker已经简化了selenium Grid的搭建流程,但是还是有很多的手动工作。需要一个一个的启动/关闭hub/nodes.

1、docker 组件启动Selenium Grid

selenium Grid通常需要启动一个hub,多个nodes像Chrome、Firefox等。我们可以把他们定义到一个文件中叫做docker-compose.yml,通过一个命令来整体启动,docker提供了一个这样的工具 –Docker-Compose。

安装docker-compose,一旦安装成功,则创建一个新的文件夹,创建文件 docker-compose.yml, docker-compose.yml内容:

version: "3"

services:

  selenium-hub:

    image: selenium/hub

    container_name: selenium-hub

    ports:

      - "4444:4444"

  chrome:

    image: selenium/node-chrome

    depends_on:

      - selenium-hub

    environment:

      - HUB_PORT_4444_TCP_ADDR=selenium-hub

      - HUB_PORT_4444_TCP_PORT=4444

  firefox:

    image: selenium/node-firefox

    depends_on:

      - selenium-hub

    environment:

      - HUB_PORT_4444_TCP_ADDR=selenium-hub

      - HUB_PORT_4444_TCP_PORT=4444

2、docker-compose命令:

运行命令启动(到docker-compose.yml路径下):docker-compose up -d

查看启动是否成功:docker-compose ps

创建更多实例:docker-compose scale chrome=5

关闭命令:docker-compose down
基于docker部署的Selenium Grid分布式自动化测试,自动化测试,软件测试,软件测试工程师,selenium,测试工具,软件测试,程序人生,自动化测试,职场发展,功能测试

浏览器打开http://localhost:4444/grid/console将会看到:
基于docker部署的Selenium Grid分布式自动化测试,自动化测试,软件测试,软件测试工程师,selenium,测试工具,软件测试,程序人生,自动化测试,职场发展,功能测试运行脚本的话直接运行就好(IP:http://localhost:4444/wd/hub) ,和上边两种的方法不太一样;不会有浏览器打开(容器内部运行),但是已经运行成功:

import unittest

from selenium import webdriver





class MyTestCase(unittest.TestCase):



    def setUp(self):

        ds = {'platform': 'ANY',

              'browserName': "chrome",

              'version': '',

              'javascriptEnabled': True

              }

        self.dr = webdriver.Remote('http://localhost:4444/wd/hub', desired_capabilities=ds)



    def test_something(self):

        self.dr.get("https://www.baidu.com")

        self.assertEqual(self.dr.name, "chrome")



    def test_search_button(self):

        self.dr.get("https://www.baidu.com")

        self.assertTrue(self.dr.find_element_by_id("su").is_displayed())



    def tearDown(self):

        self.dr.quit()





if __name__ == '__main__':

    unittest.main()

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:【文末领取】


     【下面是我整理的2023年最全的软件测试工程师学习知识架构体系图+全套资料】


一、Python编程入门到精通

二、接口自动化项目实战 

基于docker部署的Selenium Grid分布式自动化测试,自动化测试,软件测试,软件测试工程师,selenium,测试工具,软件测试,程序人生,自动化测试,职场发展,功能测试

三、Web自动化项目实战

四、App自动化项目实战 

基于docker部署的Selenium Grid分布式自动化测试,自动化测试,软件测试,软件测试工程师,selenium,测试工具,软件测试,程序人生,自动化测试,职场发展,功能测试

五、一线大厂简历

六、测试开发DevOps体系 

基于docker部署的Selenium Grid分布式自动化测试,自动化测试,软件测试,软件测试工程师,selenium,测试工具,软件测试,程序人生,自动化测试,职场发展,功能测试

七、常用自动化测试工具

八、JMeter性能测试 

基于docker部署的Selenium Grid分布式自动化测试,自动化测试,软件测试,软件测试工程师,selenium,测试工具,软件测试,程序人生,自动化测试,职场发展,功能测试

九、总结(文末尾部小惊喜)

生命不息,奋斗不止。每一份努力都不会被辜负,只要坚持不懈,终究会有回报。珍惜时间,追求梦想。不忘初心,砥砺前行。你的未来,由你掌握!

生命短暂,时间宝贵,我们无法预知未来会发生什么,但我们可以掌握当下。珍惜每一天,努力奋斗,让自己变得更加强大和优秀。坚定信念,执着追求,成功终将属于你!

只有不断地挑战自己,才能不断地超越自己。坚持追求梦想,勇敢前行,你就会发现奋斗的过程是如此美好而值得。相信自己,你一定可以做到!文章来源地址https://www.toymoban.com/news/detail-640546.html

到了这里,关于基于docker部署的Selenium Grid分布式自动化测试的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Docker部署ZooKeeper分布式协调服务

    1、准备工作 2、创建TEST容器,将conf目录COPY出来,在映射进去,方便后续维护管理! 3、运行容器 4、测试链接zookeeper 正常输出内容:

    2024年02月07日
    浏览(43)
  • 读发布!设计与部署稳定的分布式系统(第2版)笔记10_自动化和缓慢的响应

    3.3.1.1. 被隔离的节点无法正确地感知当前状态 3.3.1.2. 控制系统会感知环境,但它们有可能被愚弄 3.3.2.1. 快速启动机器 3.3.2.2. 要慢慢关机 3.3.2.3. 启动新机器要比关闭旧机器更安全 3.3.5.1. 控制层虽然每秒都能感知到系统已经过载,但它启动一台虚拟机处理负载需要花费5分

    2024年02月10日
    浏览(35)
  • 使用 Docker 部署分布式存储系统——Ceph

    最近工作中接触了一个 Python + Flask 的新项目,项目中使用了 Ceph 对象存储服务。遂在开发环境使用 Docker 搭建了一套 Ceph 集群。 Ceph 官方文档 Ceph 是一个开源的分布式存储系统,提供了对象存储、块存储和文件系统三种存储接口。Ceph 将数据存储在逻辑存储池中,使用 CRUSH 分

    2024年04月15日
    浏览(48)
  • springBoot分布式 + jdk17 部署到docker

    本地springBoot打包成jar包,上传到服务器上,再当前目录新建Dockerfile FROM openjdk:17-jdk-alpine COPY *.jar /app.jar CMD echo \\\"======dockertest======\\\" EXPOSE 8081 ENTRYPOINT [\\\"java\\\",\\\"-jar\\\",\\\"/app.jar\\\"] 进入当前目录执行: docker build -t set-day-backend-1.0.0.nsapshot . 生成新的镜像,再执行 docker run -d -p 8888:8888 --na

    2024年01月17日
    浏览(49)
  • 使用Docker部署开源分布式任务调度系统DolphinScheduler

    🔥 博客主页 : 小羊失眠啦. 🎥 系列专栏 : 《C语言》 《数据结构》 《Linux》 《Cpolar》 ❤️ 感谢大家点赞👍收藏⭐评论✍️ 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。 本篇教程和大家分享一下DolphinSc

    2024年02月05日
    浏览(60)
  • 【Docker】Docker+Zipkin+Elasticsearch+Kibana部署分布式链路追踪

    点击跳转:Docker安装MySQL、Redis、RabbitMQ、Elasticsearch、Nacos等常见服务全套(质量有保证,内容详情) 本文主要讨论在Elasticsearch和Kibana安装好合适版本的前提下,继续整合Zipkin。 一般的,它们的工作过程是这样的:Spring Cloud微服务把调用链路的日志发送给Zipkin,Zipkin把数据发

    2024年02月14日
    浏览(44)
  • 可视化分布式调度框架PowerJob部署docker版

    PowerJob(原OhMyScheduler)是全新一代分布式任务调度与计算框架,其主要功能特性如下: ● 使用简单:提供前端Web界面,允许开发者可视化地完成调度任务的管理(增、删、改、查)、任务运行状态监控和运行日志查看等功能。 ● 定时策略完善:支持 CRON 表达式、固定频率、

    2024年02月04日
    浏览(43)
  • Hadoop完全分布式安装基于Docker

    (都在root用户下) 在Dockfile文件中添加以下内容 基于centos镜像,生成带有spenssh-server、openssh-clients的镜像,用户为root,密码为a123456,镜像维护者(作者)为hadoop 建好Dockerfile文件后,生成镜像,在终端输入: 1、在主机下载ssh 2、把hadoop和jdk传到/root 3、解压hadoop和jdk 4、生成带

    2024年04月29日
    浏览(49)
  • 基于Docker搭建hdfs分布式实验环境

    理论知识 Docker Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从 Apache2.0 协议开源。Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任

    2023年04月08日
    浏览(41)
  • 基于Docker的JMeter分布式压测

    目录 前言: Docker Docker在JMeter分布式测试中的作用 Dockerfile用于JMeter基础: Dockerfile for JMeter Server / Slave: 总结 前言:         基于Docker的JMeter分布式压测是一种将JMeter测试分布在多个容器中进行的方法,可以提高测试的性能和效率。使用Docker容器化JMeter,可以轻松地在多个主

    2024年02月11日
    浏览(42)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包