Web自动化-Selenium自动化测试-8-selenium-Grid 分布式执行多个浏览器

selenium Grid 工作原理:

selenium-grid是用于设计帮助我们进行分布式测试的工具,通过Selenium Grid的可以控制多台机器多个浏览器执行测试用例,
分布式上执行的环境在Selenium Grid中称为node节点。其整个结构是由一个hub节点和若干个代理节点组成
hub用来管理各个代理节点的注册和状态信息,并且接受远程客户端代码的请求调用,然后把请求的命令再转发给代理节点来执行。
使用selenium-grid远程执行测试的代码与直接调用Selenium-Server是一样的[只是环境启动的方式不一样,需要同时启动一个hub和至少一个node]:

selenium-server-standalone下载
http://selenium-release.storage.googleapis.com/index.html

下载指定版本的selenium-server-standalone

windows启动selenium-server
在命令行输入如下命令:

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

-role hub表示启动运行hub;
-port是设置端口号,hub的默认端口是4444,这里使用的是默认的端口,当然可以自己配置;
-maxSession为最大会话请求,这个参数主要要用并发执行测试用例,默认是1,建议设置10及以上。

浏览器打开地址:http://localIp:4444/grid/console,出现如下图表示hub启动成功。

配置节点:Firfox

创建节点,在本地创建节点node1 192.168.22.1:4445 node2 192.168.22.1:4446

node节点,配置firefox浏览器,运行下面命令 (注意selenium支持firfox可以不使用 geckodriver.exe 但是要求firfox版本不可高于45.0)

java -Dwebdriver.firefox.driver="D:\Download\chrorm\geckodriver.exe" -jar selenium-server-standalone-3.141.59.jar  -role webdriver -hub http://192.168.22.1:4444/grid/register -port 4445 -maxSession 5  -browser browserName=firefox,seleniumProtocol=WebDriver,maxInstances=5,platform=WINDOWS

无报错启动后,查看页面如下:表示已经接入webDriver firfox浏览器 

 

启动第二个结点

java -Dwebdriver.chrome.driver="D:\Download\chrorm\chromedriver.exe"  -jar  selenium-server-standalone-3.141.59.jar -role node -port 4446 -hub  http://192.168.22.1:4444/grid/register   -maxSession 5  -browser browserName=chrome,seleniumProtocol=WebDriver,maxInstances=5,platform=WINDOWS

 启动无报错如下:

 

到这里就启动了两个节点了

 

Selenium Grid使用

当实例化Hub远程时,会根据配置去匹配Hub上注册的node代理节点,匹配成功后转发给代理节点,这时候代理节点会生成sessionid启动浏览器,
然后响应给Hub说一切准备就绪,Hub也会把这个sessionid响应给客户端,接下来的客户端的代码发来的请求都会被Hub转发给这个代理节点来执行。
这里实际上整个流程与Selenium1.0的原理是一样的,只是多了Hub这一层。 

DesiredCapabilities capability = new DesiredCapabilities();

capability.setBrowserName("chrome");
capability.setPlatform(Platform.WINDOWS);

try {
    WebDriver driver = new RemoteWebDriver(new URL("http://192.168.22.1:4444/wd/hub"), capability);
    driver.get("http://www.baidu.com");
    driver.quit();

} catch (MalformedURLException e) {
  e.printStackTrace();
}

通过capability设置 启动的浏览器 

node节点在hub中注册成功后,会生成一个session保存在hub中,而session中记录node的信息,当客户端代码请求hub时,
hub收到请求分析后去session里面匹配node的信息然后转发到节点运行。而根据上面代码使用hub与node节点去运行客户端代码的方式。

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员路同学

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值