Selenium Grid2
简介
使用selenium-grid可以远程执行测试的代码,核心步骤:grid --》 server--》chromedriver驱动 --》chrome浏览器
利用Selenium Grid可以使主节点(hub)的测试用例在不同主机即分支点(node)运行。可以使一份测试用例在不同环境下(操作系统、浏览器)执行自动化测试。串行,非并行。
版本
Grid1和2的原理和基本工作方式都是一样的,只是小的功能和易用性上进行了优化,例如指定测试平台的方式等。
Selenium Grid1 --> Selenium 1
Selenium Grid2 --> Selenium 1 2 3
Grid1是单独的包,Grid2已集成到Selenium Sever中,所以需要下载和运行Selenium Server才可以使用Grid2的功能。
运行条件
1、下载selenium-server-standalone-xxx.jar
2、配置Java环境
3、打开cmd(或linux终端),在selenium-server-standalone-xxx.jar文件目录下输入: java -jar selenium-server-standalone-xxx.jar 执行此jar包文件

Selenium Grid工作原理
Grid是用于设计帮助我们进行分布式测试的工具,整个结构是由一个hub主节点和若干个node代理节点组成。
hub用来管理各个代理节点的注册和状态信息,并且接收远程客户端代码的请求调用,然后把请求的命令再转发给代理节点来执行。使用Grid远程执行测试代码与直接调用Selenium Server是一样的,只是环境启动的方式不一样,需要同时启动一个hub,一个node。
<步骤>
1. 先在终端启动一个hub:(例如本地主机IP:198.127.1.100)
java -jar selenium-server-standalone-xxx.jar -role hub -port 4444 ——hub是管理,默认端口号为4444
2. 再启动若干个node:(至少启动一个node,因为hub不执行测试用例,全靠node)
java -jar selenium-server-standalone-xxx.jar -role node -port 5555 http://198.127.1.100:4444/grid ——node是小工,默认端口号是5555
java -jar selenium-server-standalone-xxx.jar -role node -port 6666
......
若指定hub分配,执行顺序:由端口连接先后,一个线程一次一个端口,轮流执行,轮流完毕又从头开始。
3. 然后,通过浏览器打开http://127.0.0.1:4444/grid/console/ 访问Grid的控制台,可以查看启动受控的节点node信息。

4. 执行代码 (参数化平台与浏览器)
from selenium.webdriver import Remote
# 指定node主机与浏览器为字典,主键不能重复
dic = {'http://127.0.0.1:5555/wd/hub':'chrome',
'http://127.0.0.1:6666/wd/hub':'firefox',
'http://198.127.1.13:5555/wd/hub':'internet explorer'
}
# 循环不同的浏览器执行脚本
for host,browser in dic.items():
print(host,browser)
dr = Remote(command_executor=host,
desired_capabilities={'platform':'ANY',
'browserName':browser,
'version':'',
'javascriptEnabled':True})
# 执行用例
dr.get("http://www.baidu.com/")
dr.find_element_by_id("kw").send_keys("selenium grid")
dr.find_element_by_id("su").click()
dr.quit()
print("OK")
<注意>
启动远程节点需要满足的条件:
1. 两平台相互ping通
2. 远程节点java/selenium-server启动受控
3. 具备相关的浏览器,否则会被拒绝
Remote应用
remote类可以启动server且指定不同ip和端口(grid=运行多平台多浏览器)
解释:
- 由selenium包的代码可知,selenium/webdriver/__init__.py得知引用的WebDriver类的真实目录
from .chrome.webdriver import WebDriver as Chrome
- 然后由selenium/webdriver/chrome/webdriver.py得知
from selenium.webdriver.remote.webdriver import WebDriver as RemoteWebDriver
class WebDriver(RemoteWebDriver):
def __init__(self, executable_path="chromedriver", port=0,
chrome_options=None, service_args=None,
desired_capabilities=None, service_log_path=None):
- Chrome的webdriver类也是继承了selenium.webdriver.remote.webdriver.py文件中的WebDriver类,所以打开此目录
class WebDriver(object):
_web_element_cls = WebElement
def __init__(self, command_executor='http://127.0.0.1:4444/wd/hub',
desired_capabilities=None, browser_profile=None, proxy=None,
keep_alive=False, file_detector=None):
- 由remote的WebDriver类中得知desired_capabilities(浏览器配置)必须不为空,输入格式为字典。
-浏览器的配置由desired_capabilities参数决定,这个参数的秘密再selenium包的webdriver/common目录下的desired_capabilities.py文件中
CHROME = {
"browserName": "chrome", #浏览器
"version": "", #浏览器版本号
"platform": "ANY", #测试平台
"javascriptEnabled": True, #Js启动状态
}
所以从Remote()方法配置来看,它相当于我们直接使用webdriver.Chrome(),但是Remote()却大大增加了配置的灵活性。(请看上面执行代码)
总结:个人理解,remote是早期selenium1便存在,后来webdriver是继承了它也重写了它。所以早期remote是通过RC执行脚本,不需要驱动;但现在到selenium3,只存在webdriver那样的工作方式。
所以曾在selenium1合并过来的grid --》 server--》chromedriver驱动 --》chrome浏览器,也是用webdriver工作方式在跑。
Selenium Grid2的更多相关文章
- Python+selenium之selenium Grid2
利用selenium grid2 keyi可以在不同的主机上建立主节点(hub)和分支节点(node),可以使主节点上的测试用例在不同的分支节点上运行.对不同的节点来说,可以搭建不同的测试环境(操作系 ...
- 9、Selenium grid2
P228--Selenium Grid2 P233--Selenium Grid 工作原理 P236--Remote 应用 P246--WebDriver 驱动 driver = webdriver. ...
- selenium Grid2 分布式自动化测试环境搭建
一.Selenium Server 环境配置 1.selenium grid的组成与作用:由一个集线器hub和多个客户机node组成,如果你的程序需要在不用的浏览器,不同的操作系统上测试,而且比较多的 ...
- selenium grid2 使用远程机器的浏览器
下载 selenium-server-standalone-3.4.0.jar包 在selenium-server-standalone-3.4.0.jar包目录下面执行cmd 命令 java -ja ...
- selenium Grid2环境搭建和基本使用
Selenium Grid简介 利用Selenium Grid可以使主节点(hub)的测试用例在不同主机即分支点(node)运行.可以使一份测试用例在不同环境下(操作系统.浏览器)执行自动化测试.Se ...
- Selenium WebDriver + Grid2 + RSpec之旅(二)----Grid2的配置
Selenium WebDriver + Grid2 + RSpec之旅(二) ----Grid2的配置 为什么要使用Selenium-Grid 分布式运行大规模的TestCase 能够通过一个中央节 ...
- Selenium WebDriver + Grid2 + RSpec之旅(一)----准备篇
Selenium WebDriver + Grid2 + RSpec之旅(一) ----准备篇 前言 在Web 2.0 应用中,在浏览器种类盛行的时代,我们在测试过程中不仅要模 ...
- Robot Framework和Selenium 2 Grid集成指南
1. 环境搭建 A. 所需软件 1. Selenium2Lib 1.0.1 这个特性需要用到Selenium2Lib的最新版本1.0.1,但是这个版本还有一些iframe支持和IE支持的问题需要修改, ...
- Selenium自动化测试,接口自动化测试开发,性能测试从入门到精通
Selenium自动化测试,接口自动化测试开发,性能测试从入门到精通Selenium接口性能自动化测试基础部分:分层自动化思想Slenium介绍Selenium1.0/2.0/3.0Slenium R ...
随机推荐
- recyclerview item点击事件
recyclerview早就不陌生了,比起过去传统的listView,样式更多,也较为高效一点,这里整理一下recylerview中item的点击事件. recyclerview和listView不同 ...
- solr 学习之简介及安装
一.solr简介 Solr 是Apache下的一个顶级开源项目,采用Java开发,它是基于Lucene的全文搜索服务器.Solr提供了比Lucene更为丰富的查询语言,同时实现了可配置.可扩展,并对索 ...
- MySQL调优三步曲(慢查询、explain profile)
在做性能测试中经常会遇到一些sql的问题,其实做性能测试这几年遇到问题最多还是数据库这块,要么就是IO高要么就是cpu高,所以对数据的优化在性能测试过程中占据着很重要的地方,下面我就介绍一些msyql ...
- 大数据系列之Hadoop分布式集群部署
本节目的:搭建Hadoop分布式集群环境 环境准备 LZ用OS X系统 ,安装两台Linux虚拟机,Linux系统用的是CentOS6.5:Master Ip:10.211.55.3 ,Slave ...
- MP3 信息读取
MP3 信息读取 运行环境:Window7 64bit,.NetFramework4.61,C# 7.0: 编者:乌龙哈里 2017-03-13 参考: MP3-wikipedia ID3v1 MPE ...
- solr home 目录设置
对于在tomcat 中部署solr 来说,有以下三处可以配置 solr.solr.home(即solr的数据文件位置): 1. 在解压缩solr.war后的webapps/solr 中的WEB-INF ...
- 修改Delphi 10.1.2 edit控件在android的复制、剪切和粘贴样式
Delphi 10.1.2 edit控件在android默认的复制.剪切和粘贴样式太丑,经悟能-DelphiTeacher的提示,用最简单的代码修改后稍有改观. 默认的样式: 修改后的样式: 修改FM ...
- jquery实现名单滚动
转:http://www.qdfuns.com/notes/25341/917d9cb031f835a086dd445b77b6e04e.html 介绍:记录滚动特效.就是那一排文字不停地滚啊滚啊滚得 ...
- ubuntu如何进入local、bin目录
回到home目录,输入命令:cd /usr/local 若要进入bin目录,输入命令:cd /usr/local/bin
- 将 shell 脚本打包到 rpm 包中
下以操作最好在虚拟机上操作:如 Docker 最方便了 1. 安装 rpmbuild yum -y install rpmbuild rpmdevtools -y 2. 生成打包路径 使用 rpmd ...