我的理解就是分佈式測試,可在不一樣的操做系統、瀏覽器上,能夠分佈式運行自動化測試用例,提升測試執行效率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瀏覽器同時在運行。