Selenium Grid- 让自动化分布式执行变得可能

什么是 Selenium Grid?

Selenium Grid 是 Selenium 的三大组件之一,允许用户同时在不同的机器和系统上测试不同浏览器。

也就是说 Selenium Grid 支持分布式的测试执行。它可以让你的测试用例在一个分布式的执行环境中运行。

由上图可见,测试脚本会通过 selenium hub 节点分发给不同的 node 节点,而不同的 node 节点所在的操作系统和搭载的浏览器类型可以是不同的,接下来我们看下 hub 节点和 node 节点具体分别有什么作用:

hub 节点

中心节点,或总控节点

管理各个 node 节点的注册信息和状态信息

接收并转发客户端(测试脚本)请求到合适的 node 节点

node 节点

子节点,或代理节点

负责注册配置信息到 hub 节点(平台、浏览器、浏览器版本等)

负责接收来自 hub 节点的转发的请求以执行测试脚本

也可单独作为远程节点执行测试脚本

环境准备

环境说明:

本地端系统为 win10,搭载 V68 版本的 Chrome 浏览器,IP 地址为 192.168.1.222

远程端系统为 win7,搭载 V56 版本的 Firefox 浏览器,IP 地址为 192.168.140.130

两台主机能够相互 ping 通

hub 节点和 node1 节点都是在本地端工作,node2 节点在远程端工作

环境准备步骤:

测试机器安装 JDK,配置环境变量

下载 selenium-server-standalone-x.x.x.jar

https://npm.taobao.org/mirrors/selenium

下载浏览器驱动

Chrome:https://npm.taobao.org/mirrors/[chromedriver](https://so.csdn.net/so/search?q=chromedriver&spm=1001.2101.3001.7020 "chromedriver")

Firefox:https://npm.taobao.org/mirrors/geckodriver/

IE:https://npm.taobao.org/mirrors/selenium 注:IE 驱动和 selenium 依赖在一起

配置运行

1、本地端启动 hub

java -jar selenium-server-standalone-3.141.59.jar -role hub -port 8888 -maxSession 10

参数解释:

Java -jar selenium-server-standalone-3.141.59.jar 运行 jar 包

-role hub 以 hub 的角色运行

-port 8888 指定 hub 运行的端口(默认为 4444)

-maxSession 10 最大的处理会话

2、查看 hub 的运行状态

浏览器中输入 http://localhost:8888/grid/console 进入到到 hub 的 console 控制台

3、启动 node1

node1 节点工作在本地端,配置的浏览器为 V68 的 Chrome

复制代码
java -Dwebdriver.chrome.driver="chromedriver.exe" -jar selenium-server-standalone-3.141.59.jar -role node -hub "http://192.168.4.4:8888/grid/register" -port 5558 -browser "browserName=chrome,maxInstances=2,version=68,platform=WINDOWS"

参数解释:

-Dwebdriver.chrome.driver="chromedriver.exe" 指定 chromeDriver 驱动所在的路径(本地)

-jar selenium-server-standalone-3.141.59.jar 运行 jar 包

-role node 以 node 角色执行

-hub "http://192.168.1.222:8888/grid/register" 指定要链接的 hub 地址,这样 node 才能和 hub 通讯连接上

-port 5558 node 的执行端口

-browser "browserName=chrome,maxInstances=2,version=68,platform=WINDOWS"

browserName=chrome 运行的浏览器名称

maxInstances=2 最多支持两个浏览器实例

version=68 浏览器版本号

platform=WINDOWS 平台名称

运行之后的效果:

浏览器再次刷新访问 hub 的 console 端

4、启动远程端的 node2 节点

node2 节点工作在远程端,配置的浏览器为 V56 的 Chrome

启动配置为

复制代码
java  -Dwebdriver.firefox.driver="geckodriver.exe" -jar selenium-server-standalone-3.141.59.jar -role node -hub "http://192.168.140.1:8888/grid/register" -port 5558  -browser "browserName=firefox,maxInstances=2,version=56,platform=WINDOWS"

浏览器再次刷新访问 hub 的 console 端,可以看到两个 node 节点已经成功注册到 hub 节点上

执行脚本

python 复制代码
// 期望能力对象

DesiredCapabilities capabilities = new DesiredCapabilities();

//配置测试的浏览器,配置Chrome则会启动本地node1节点浏览器进行测试,配置Firefox则会启动远程端的Firefox进行测试

capabilities.setBrowserName(BrowserType.CHROME);

// hub节点

String url = "http://192.168.1.222:8888/wd/hub";

//和hub建立通讯,把相应配置传给hub,hub会根据配置选择注册的node节点,打开相应的浏览器进行测试

WebDriver driver = new RemoteWebDriver(new URL(url), capabilities);

driver.get("http://www.baidu.com");

driver.findElement(By.id("kw")).sendKeys("柠檬班软件测试");

Thread.sleep(10000);

driver.quit();

通过上述配置及脚本我们能够启动本地 node1 节点和 node2 节点分别进行测试,单 node 节点只能支持一款浏览器进行测试,如何让 node 节点可以支持多款浏览器呢?

答案就是在配置 node 节点的时候传入的参数配置兼容多款浏览器即可。

node 节点配置兼容不同浏览器

node 节点可以配置单一浏览器,如 Chrome、Firefox、IE 等等,也可以配置兼容多款浏览器

这样只要符合 node 节点配置中的任何一个,hub 会将客户端的执行请求发送过来

复制代码
java -Dwebdriver.ie.driver="IEDriverServer.exe" -Dwebdriver.chrome.driver="chromedriver.exe" -Dwebdriver.firefox.driver="geckodriver.exe" -jar selenium-server-standalone-3.141.59.jar -role node -hub "http://192.168.140.1:8888/grid/register" -port 5555  -browser "browserName=internet explorer,maxInstances=4,version=11,platform=WINDOWS" -browser "browserName=chrome,maxInstances=2,version=68,platform=WINDOWS" -browser "browserName=firefox,maxInstances=3,version=56,platform=WINDOWS"

现在 node1 节点和 node2 节点采用相同的启动参数配置启动

我们可以看到,grid 的 console 控制台显示两个 node 节点都可以支持多浏览器测试

node 节点启动方式二

之前启动的方式是通过命令行或者 bat 脚本启动 node 节点,官方提供了两种方式,其二就是通过 JSON 配置文件启动

复制代码
java -jar selenium-server-standalone-3.141.59.jar -role node -nodeConfig node.json

node.json 配置文件如下:

python 复制代码
{

"capabilities":

[

{

"browserName": "firefox",

"maxInstances": 5,

"seleniumProtocol": "WebDriver",

"webdriver.firefox.driver":"firefox.exe",

#"firefox_binary":"D:\\Program Files\\Mozilla Firefox\\firefox.exe",

"platform":"WINDOWS"

},

{

"browserName": "chrome",

"maxInstances": 5,

"seleniumProtocol": "WebDriver",

"webdriver.chrome.driver":"chromedriver.exe",

"platform":"WINDOWS"

},

{

"browserName": "internet explorer",

"maxInstances": 5,

"seleniumProtocol": "WebDriver",

"platform":"WINDOWS"

}

],

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

"maxSession": 5,

"port": -1,

"register": true,

"registerCycle": 5000,

"hub": "http://192.168.1.222:8888",

"nodeStatusCheckTimeout": 5000,

"nodePolling": 5000,

"role": "node",

"unregisterIfStillDownAfter": 60000,

"downPollingLimit": 2,

"debug": false,

"servlets" : [],

"withoutServlets": [],

"custom": {}

}

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

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!

相关推荐
代码AI弗森17 分钟前
n8n 专题:从“自动化脚本”到“可视化工作流引擎”(自建、节点、Webhook、生产部署)
运维·自动化
云捷配低代码2 小时前
低代码与定制开发:复杂业务场景适配度分析
低代码·自动化·数字化·敏捷流程·数字化转型
刘一说2 小时前
Spring Cloud微服务中的分布式追踪:从故障定位到性能优化的革命性实践
分布式·spring cloud·微服务
盈创力和20073 小时前
以太网温湿度传感器如何提升机房环境监控的自动化与可靠性?
运维·自动化·以太网温湿度传感器·多协议支持·网络型温湿度传感器·物联网温湿度变送器·双重供电温湿度传感器
北京耐用通信4 小时前
告别通信干扰与距离限制:耐达讯自动化Profibus总线光纤中继器赋能伺服驱动器稳定连接
人工智能·科技·网络协议·自动化·信息与通信
旦莫4 小时前
Python测试开发工具库:测试环境变量统一配置与加载工具
python·测试开发·自动化·ai测试
程序员三藏5 小时前
软件测试环境搭建及测试过程
自动化测试·软件测试·python·功能测试·测试工具·职场和发展·测试用例
程序员agions6 小时前
Node.js 爬虫实战指南(三):分布式爬虫架构,让你的爬虫飞起来
分布式·爬虫·node.js
运维行者_6 小时前
远程办公场景 NFA:从网络嗅探与局域网流量监控软件排查团队网络卡顿问题
运维·服务器·开发语言·网络·自动化·php