我的理解就是分布式测试,可在不一样的操做系统、浏览器上,能够分布式运行自动化测试用例,提升测试执行效率java
一、使用selenium提供的服务端独立jar包,selenium-server-standalone-3.9.1.jarnode
二、对应浏览器驱动如chromedriver.exe,IEDriverServer.exeweb
三、创建服务端、客户端都是运行于java环境chrome
hub,即服务中心(服务机:192.168.1.106),建立名为hub.bat的文件,内容以下:json
Java -jar selenium-server-standalone-3.9.1.jar -role hub -port 6655
双击建立hub.bat,以下图:浏览器
说明:安全
建立node节点,即节点机(192.168.1.118),建立名为node.bat的文件多线程
node配置文件以下:并发
java -jar selenium-server-standalone-2.48.2.jar -role node -hub "http://192.168.1.105:4444/grid/register" -port 6655
-Dwebdriver.ie.driver="D:\node\IEDriverServer.exe"
-Dwebdriver.chrome.driver="D:\node\chromedriver.exe"
-Dwebdriver.firefox.bin="F:\Program Files (x86)\Mozilla Firefox\firefox.exe"
-browser "browserName=internet explorer,maxInstances=5,version=11,platform=WINDOWS"
-browser "browserName=chrome,maxInstances=2,version=47,platform=WINDOWS"
-browser "browserName=firefox,maxInstances=3,version=38,platform=WINDOWS"分布式
java -jar selenium-server-standalone-3.9.1.jar -role node -hub "http://192.168.1.106:4444/grid/register" -Dwebdriver.ie.driver="E:\node\IEDriverServer.exe" -Dwebdriver.chrome.driver="E:\node\chromedriver.exe" -browser "browserName=internet explorer,maxInstances=5,version=8,platform=WINDOWS" -browser "browserName=chrome,maxInstances=2,version=76,platform=WINDOWS"
说明:
-role node 表示这次咱们注册的是node节点。
-hub http://192.168.1.106:4444/grid/register 表示我这次注册的node节点,是注册到我上次启动的hub中的。
192.168.1.106:是hub机器的ip,若是要实现多台机器的注册,须要先保证hub,和node的机子在同一个局域网中。
双击建立node.bat,便可启动
node机器显示以下图:
hub注册成功显示以下:
红圈处提示注册成功,console显示以下:
经过selenium gird,在node机器上使用谷歌及ie打开百度首页,搜索Refain 博客园,并打印页面标题
建立名为RemoteWebDriverUtil的类,用来封装各个浏览器初始化时使用,具体代码以下:
package com.brower.demo; import java.net.MalformedURLException; import java.net.URL; import org.openqa.selenium.Platform; import org.openqa.selenium.WebDriver; import org.openqa.selenium.chrome.ChromeOptions; import org.openqa.selenium.ie.InternetExplorerDriver; import org.openqa.selenium.remote.DesiredCapabilities; import org.openqa.selenium.remote.RemoteWebDriver; /** * @author longrong.lang */ public class RemoteWebDriverUtil { static WebDriver driver; // 远程调用ie浏览器 public static WebDriver createRemoteIEDriver() { System.setProperty("webdriver.ie.driver", "tool/IEDriverServer.exe"); // 指定调用IE进行测试 DesiredCapabilities capability = DesiredCapabilities.internetExplorer(); // 避免IE安全设置里,各个域的安全级别不一致致使的错误 capability.setCapability(InternetExplorerDriver.INTRODUCE_FLAKINESS_BY_IGNORING_SECURITY_DOMAINS, true); // 链接到selenium hub,远程启动浏览器 capability.setPlatform(Platform.XP); try { driver = new RemoteWebDriver(new URL("http://192.168.1.118:5555/wd/hub"), capability); } catch (MalformedURLException e) { // TODO Auto-generated catch block e.printStackTrace(); } return driver; } // 启用远程调用chrome public static WebDriver createRemoteChromeDriver() { System.setProperty("webdriver.chrome.driver", "tool/chromedriver.exe"); ChromeOptions options = new ChromeOptions(); options.addArguments("test-type"); options.addArguments("--disable-extensions--"); options.addArguments("proxy=null"); DesiredCapabilities capability = DesiredCapabilities.chrome(); capability.setBrowserName("chrome"); capability.setPlatform(Platform.XP); try { driver = new RemoteWebDriver(new URL("http://192.168.1.118:5555/wd/hub"), capability); } catch (MalformedURLException e) { // TODO Auto-generated catch block e.printStackTrace(); } return driver; } // 启用远程调用firefox public static WebDriver createRemoteFirefoxDriver() { DesiredCapabilities capability = DesiredCapabilities.firefox(); capability.setBrowserName("firefox"); capability.setPlatform(Platform.XP); try { driver = new RemoteWebDriver(new URL("http://192.168.1.106:4444/wd/hub"), capability); } catch (MalformedURLException e) { // TODO Auto-generated catch block e.printStackTrace(); } return driver; } }
再建立一个名为TestSeleniumGrid的测试类,用于测试是否能够正常执行,具体示例代码以下:
package com.brower.demo; import org.openqa.selenium.By; import org.openqa.selenium.WebDriver; import org.testng.annotations.Test; public class TestSeleniumGrid { @Test public void testSeleniumGrid1() { WebDriver chromeDriver = RemoteWebDriverUtil.createRemoteChromeDriver(); chromeDriver.get("https://www.baidu.com/"); chromeDriver.findElement(By.id("kw")).sendKeys("Refain 博客园"); chromeDriver.findElement(By.id("su")).click(); System.out.println(chromeDriver.getTitle()); } @Test public void testSeleniumGrid2() { WebDriver ieDriver = RemoteWebDriverUtil.createRemoteIEDriver(); ieDriver.get("https://www.baidu.com/"); ieDriver.findElement(By.id("kw")).sendKeys("Refain 博客园"); ieDriver.findElement(By.id("su")).click(); System.out.println(ieDriver.getTitle()); } }
引用某大神的总结,地址我忘记了3年前写的,今天来翻新下,惭愧呀
多线程并发运行WebDriver的步骤:
下面说下具体实现方法。
1.运行hub。在命令行中输入:java -jar selenium-server-standalone-2.37.0.jar -role hub -maxSession 40 -port 4444
参数中必须指明-role hub 才是运行hub。默认端口是4444,若是端口被占用就须要指定其余。-maxSession是最大处理的会话请求,我这里设置为40。若是不指定的话,默认是1(即单线程模式了)。
2.运行node。(先说下运行一个node状况)在命令行中输入(下面的命令是一行敲完):
java -Dwebdriver.ie.driver=D:\IEDriverServer.exe -jar selenium-server-standalone-2.37.0.jar -role node -hub http://127.0.0.1:4444/grid/register -maxSession 20 -browser "browserName=internet explorer,version=9,platform=WINDOWS,maxInstances=20" -port 5555 ,因为node是能够运行在不通系统上的,因此指定驱动位置-Dwebdriver.ie.driver=D:\IEDriverServer.exe。参数中必须指明-role node才是运行node。参数-hub 后面是第一步中hub的IP和端口:http://hub的IP:端口/grid/register 。node默认的maxSession的值就是5(最多并发5个浏览器),即启动一个node会默认有5个firefox、1个chrome、1个IE的实例。若是用IE浏览器的话,就算你的测试case是多线程,最终也会是一个一个的执行。可是若是在后面的-browser的参数中指明maxInstances=5,那么就会同时运行5个浏览器。-browser参数是指明node能够用的浏览器信息。注意,若是node的maxSession和maxInstances设置的有问题,那么hub的命令窗口中会给出警告。经过这里可以知道你的node是否设置成功。运行node后,窗口中也会显示该node的信息。-port是端口号,默认端口是5555,若是端口被占用就须要指定其余。若是你启动第二个node的话,端口就必须指定了,不能是5555。
我设置的node是只运行IE,而且并发数是20,最多有20个IE浏览器在运行。node中的maxSession的值不能超过hub中的。若是想多线程并发要在hub和node的参数中同时指明maxSession值。node中若是用IE浏览器,指明maxSession后还须要指明一样大小的maxInstances值。个人例子最终会同时运行20个IE浏览器。maxSession是说node能够有几个浏览器同时运行,而maxInstances是说某个浏览器能够有几个同时运行。因为个人电脑运行20个IE已经有些卡了,那么能够再另一个电脑上再运行一个20Session大小的node。我的测试结果:运行一个20Session大小的node和运行2个10Session大小的node没什么差异。运行多个node主要仍是为了可以分布式的测试,不至于一个电脑打开太多浏览器。
3.运行test case。首先将上面代码中的44和47行注释掉,将48行注释打开。咱们须要用远程的方式将请求提交给hub(后面的/wd/hub是固定的)。
WebDriver driver = new RemoteWebDriver(new URL("http://hub的IP:端口/wd/hub"),capability);
因为是远程的方式,因此44行的设置就没什么用了。下面你能够运行你的程序了,你会发现同时启动20个线程,就会有20个IE浏览器同时在运行。