Selenium 远程运行
Selenium 多机版本
Selenium Server介绍
- Selenium Grid用于进行分布式测试,利用它可以在不同的主机上建立主节点(hub)和分支节点(node)。
- 对于不同的节点,可以搭建不同的测试环境(操作系统、浏览器),从而使一份测试用例得到在不同环境下的执行结果。
- Grid2 已完全集成到 Selenium Server中,并完全支持selenium 2的所有功能。
当测试用例需要执行的环境比较多时,可以利用多线程技术并行地执行这些用例从而缩短耗时。
Selenium Server 服务启动
Selenium Server 服务有jar包和docker 镜像 本文演示 jar启动
jar包名称:selenium-server-standalone-3.5.3.jar
启动Selenium Server(默认启动一个hub):
1
java -jar selenium-server-standalone-3.5.3.jar
在一台主机同时启动多个node节点(port可选,hub 和 node默认端口号分别为 4444 和 5555):
1
2
3java -jar selenium-server-standalone-3.5.3.jar -role hub -port 4444
java -jar selenium-server-standalone-3.5.3.jar -role node -port 5555
java -jar selenium-server-standalone-3.5.3.jar -role node -port 5556在不同测试环境的主机启动一个node节点
1
java -jar selenium-server-standalone-3.5.3.jar -role node [-port] <5555> -hub http://<hub_host_ip>:4444/grid/register
//启动远程node的要求:
1). 本地hub与远程node主机之间必须能够ping通。
2). 远程主机必须安装了执行用例所需的浏览器以及驱动,并且驱动需要在环境变量path的目录下。
3). 远程主机必须配置了Java环境,因为要运行Selenium Server。在hub主机浏览器窗口打开以下地址,查看hub状态。
http://localhost:4444/grid/console
调用代码
1 | from selenium.webdriver import Remote |