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节点去运行客户端代码的方式。