selenium-server-standalone 分布式自动化测试 搭建

絕刀狂花
发布: 2025-08-30 08:56:30
原创
443人浏览过

为了在不改变文章大意的情况下进行伪原创,以下是重新组织和改写的文本:


准备好在Linux(使用CentOS7作为Hub服务)和Windows(Win10作为节点)主机上搭建Selenium Grid环境了吗?本文将指导您完成Java环境、Python3环境和Selenium Grid的安装和配置。

根据Selenium官方网站的介绍,Selenium支持分布式测试,需要部署Grid服务。Selenium Grid是Selenium套件的一部分,专门用于在不同的浏览器、操作系统和机器上并行运行多个测试用例。

使用Selenium Grid的好处包括:

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

首先,从Selenium官方网站下载稳定且较新的selenium-server-standalone版本。下载地址为:https://www.php.cn/link/95d2e07a0caa3ad6abc065d1ac24ab25

将下载好的selenium-server-standalone-3.141.59.jar包传输到Linux服务器上。在Linux主机上,进入到jar包所在目录,执行以下命令启动Hub服务:

java -jar selenium-server-standalone-3.141.59.jar -role hub -host 0.0.0.0
登录后复制

启动Hub服务后,控制台会显示类似以下信息:

[root@gitlab download]# java -jar selenium-server-standalone-3.141.59.jar -role hub -host 0.0.0.0
Picked up _JAVA_OPTIONS: -Xms64m -Xmx64m -Xmn32m
11:45:08.914 INFO [GridLauncherV3.parse] - Selenium server version: 3.141.59, revision: e82be7d358
11:45:08.974 INFO [GridLauncherV3.lambda$buildLaunchers$5] - Launching Selenium Grid hub on port 4444
2021-05-19 11:45:09.339:INFO::main: Logging initialized @581ms to org.seleniumhq.jetty9.util.log.StdErrLog
11:45:09.459 INFO [Hub.start] - Selenium Grid hub is up and running
11:45:09.460 INFO [Hub.start] - Nodes should register to http://172.17.0.1:4444/grid/register/
11:45:09.460 INFO [Hub.start] - Clients should connect to http://172.17.0.1:4444/wd/hub
11:46:27.116 INFO [DefaultGridRegistry.add] - Registered a node http://192.168.89.148:5555
登录后复制

在同一局域网内的本地浏览器中,访问地址http://:4444/grid/console,您可以查看当前是否有注册的节点。

selenium-server-standalone 分布式自动化测试 搭建

接下来,在Windows主机上下载并配置chromedriver。下载地址为:https://www.php.cn/link/8dda35ae49b8bce604b98729e2a5b424

白瓜面试
白瓜面试

白瓜面试 - AI面试助手,辅助笔试面试神器

白瓜面试 40
查看详情 白瓜面试

如果遇到“DevToolsActivePort file doesn't exist”的错误,请按照相关解决方案进行处理。

在Windows机器上,进入下载好的selenium-server-standalone-3.141.59.jar目录,执行以下命令将节点注册到Hub:

java -jar selenium-server-standalone-3.141.59.jar -role node -port 5555 -hub http://192.168.88.253:4444/grid/register/
登录后复制

selenium-server-standalone 分布式自动化测试 搭建

最后,在Hub上分发任务并执行脚本。在Linux主机上创建并运行以下Python脚本:

# t.py
from selenium.webdriver import Remote
from time import sleep
<h1>这里lists的command_executor就是节点的ip:port----><a href="https://www.php.cn/link/a621f7ab8fd0eae3805566885dda4a25">https://www.php.cn/link/a621f7ab8fd0eae3805566885dda4a25</a></h1><p>lists = {'<a href="https://www.php.cn/link/163e836b057fa98808f41048cba1195f">https://www.php.cn/link/163e836b057fa98808f41048cba1195f</a>': 'chrome',
}</p><p>for host, browser in lists.items():
print(host, browser)
driver = Remote(command_executor=host,
desired_capabilities={'browserName': browser,
'platform': 'ANY',
'version': '',
'javascriptEnabled': True
}
)
driver.get("<a href="https://www.php.cn/link/f228bda69952fa13fe74d09b34e4983b">https://www.php.cn/link/f228bda69952fa13fe74d09b34e4983b</a>")
driver.maximize_window()
sleep(1)
driver.find_element_by_xpath("//input[@id='kw' and @class='s_ipt']").send_keys(browser)
sleep(1)
driver.find_element_by_xpath("//input[@value='百度一下' and @id='su']").click()
sleep(3)
result_text = driver.find_element_by_xpath("//span[@class='nums_text']").text
sleep(1)
assert "百度为您找到相关结果约" in result_text
sleep(1)
driver.quit()
登录后复制

在Linux主机上执行

python3 t.py
登录后复制
,您将看到节点机器正在运行测试任务。

selenium-server-standalone 分布式自动化测试 搭建

通过以上步骤,您已经成功搭建了Selenium Grid环境,并能够在分布式环境中执行自动化测试任务。

以上就是selenium-server-standalone 分布式自动化测试 搭建的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号