Selenium Grid - 集中管理多個Selenium測試節點

原先針對5台測試機器想直接部屬5個架設Selenium Server的VM,給與一對一的資源分配進行測試。但由於會跑測試的機器並不只這5台,因此開始思考資源分配問題。於是我想: 只要寫一個集中管理的Server,其餘的Selenium Server會對此Server註冊,並由它分配資源不就好了? 後來又想想: Selenium做這麼久了,肯定早有Solution。沒錯! 就是Selenium Grid!接著我將告訴大家Selenium Grid該如何使用。

在先前介紹Remote Selenium時,所使用的Selenium Standalone Server(v2.48.2),本身就攜帶著Grid的功能。以節點角色而言,分為hub與node。

Hub - 負責管理分配Node資源

啟動腳本:

@echo off
set BASE=%~dp0
set JAVA_PATH=%BASE%jre7\bin\java.exe
set PATH=%PATH%;%BASE%;
set JAVA_OPTS="-Xms128m -Xmx1024m"
 
cd /d "%BASE%"
"%JAVA_PATH%" "%JAVA_OPTS%" -jar selenium-server-standalone-2.48.2.jar -role hub

執行畫面,已接收來自192.168.1.29的連線:


可以連線至http://hub_ip:4444/grid/console去查詢連線狀態:


測試案例在Open Browser的remote_url參數只要指定到http://hub_ip:4444/wd/hub即可。如果測試案例等待時間長,可以透過-timeout ${num}參數去改變release node的時間,預設為300秒(${num}=300)。

Node - 負責執行測試

啟動腳本:

@echo off
set BASE=%~dp0
set JAVA_PATH=%BASE%jre7\bin\java.exe
set PATH=%PATH%;%BASE%;
set HUB_IP=192.168.1.150 
set JAVA_OPTS="-Xms128m -Xmx1024m"
 
cd /d "%BASE%"
"%JAVA_PATH%" "%JAVA_OPTS%" -jar selenium-server-standalone-2.48.2.jar -role node -hub http://%HUB_IP%:4444/grid/register

執行畫面:

在參數加上-maxSession ${num}去限制node可接受Session的數量。