Selenium Grid分佈式測試環境搭建

Selenium Grid簡介

Selenium Grid實際上是基於Selenium RC的,而所謂的分佈式結構就是由一個hub節點和若干個node代理節點組成。Hub用來管理各個代理節點的註冊信息和狀態信息,並且接受遠程客戶端代碼的請求調用,然後把請求的命令轉發給代理節點來執行(官方說明)

簡單來說通過selenium grid可以實現一臺服務器控制多臺node節點機器遠程執行selenium自動化測試腳本。比如自動化測試腳本存放在一臺hub主機上,那麼通過grid就可以控制多臺node客戶端來執行hub主機上的自動化測試腳本,下面我們就開始配置一下分佈式測試運行環境

環境準備

其實hub主機和node節點可以同時配置在一臺物理機上,但是爲了模擬真實的測試環境,我準備了2臺真實的物理機,當然你也可以使用一臺物理機+虛擬機的方式練習

1. 準備2臺處於同一個局域網下的物理機,保證2臺物理機能夠相互ping通

2.下載selenium-server-standalone包

3.作爲node節點的物理機需要配置好瀏覽器和對應驅動,並把驅動程序加入環境變量

4.hub主機和node主機均需要配置java jdk 1.8 (切記本版,否則可能配置不成功)

問題

如果你的兩臺機器處於同一個網絡,但是無法相互ping通,你可以嘗試下面的辦法解決

打開控制面板-打開防火牆設置-點擊【高級設置】-點擊【入站規則】找到下面兩個規則並開啓

下載selenium-server-standalone

訪問官網 https://www.seleniumhq.org/download/ 下載 selenium-server-standalone

下載好selenium-server-standalone-3.141.59.jar包後,分別放到兩臺電腦的任意位置

配置瀏覽器驅動

瀏覽器驅動如何配置,請自行百度(谷歌的驅動可以從這裏下載https://npm.taobao.org/mirrors/chromedriver),我後面主要使用的是firefox瀏覽器

安裝JDk

https://www.cnblogs.com/linuxchao/p/linuxchao-jenkins-setup.html 我的這篇文章裏面有安裝jdk的教程,但是請注意jdk的版本

搭建環境

配置hub主機

我選擇作爲hub主機的地址爲:192.168.1.103

打開cmd終端,並切換到selenium-server-standalone-3.141.59.jar所在的目錄下,執行命令:java -jar selenium-server-standalone-3.141.59.jar -role hub

執行命令後,會初始化本機爲hub服務器,自動分配一個ip地址(如圖,這個地址是個虛擬地址,作爲hub的主機地址,因爲同一臺機器可以同時作爲hub和note,所以會自動生成一個虛擬地址),端口號默認爲4444,當然你在初始化hub主機的時候也可以修改默認端口,添加-port=指定端口號即可

初始化完成後,我們可以訪問http://192.168.24.1:4444:/grid/console來查看初始化的hub狀態如圖

配置node節點

我選擇的node節點機器的地址爲:192.168.1.102

同樣打開cmd終端,並切換到selenium-server-standalone-3.141.59.jar所在的目錄下,執行命令:

java -jar selenium-server-standalone-3.141.59.jar -role webdriver -browser "browserName=firefox,platform=WINDOWS" -hubHost 192.168.1.103(hub所在的主機地址)

如果你使用的瀏覽器是chrome,可能你需要執行這個命令(別問我爲什麼,我使用chrome瀏覽器的時候,使用上面的命令,只是修改了browserName=chrome,沒有成功)

java -jar -Dwedriver.chrome.driver=driver所在的目錄\chromedriver.exe selenium-server-standalone-3.141.59.jar -browser "browserName=chrome, version=75" -role node -hubHost 192.168.1.103

命令執行完畢後你會看到下面的輸出信息

ok,現在我們再次訪問一下hub主機的地址看下狀態

右邊就是我初始化成功後的遠程node節點機器的配置,左邊我也配置了一個,是在hub所在的主機配置的一個note節點

到這裏,我們的分佈式自動化測試環境就配置完成了,接下來開始編寫我們的測試代碼,看下是否能夠在遠程note機器上執行測試

測試腳本

測試腳本放在hub所在的機器(我們的目的就是控制遠程note機器執行測試(打開瀏覽器執行測試),並不是hub所在機器執行(要不然還有啥意義呢?))

"""
------------------------------------
@Time : 2019/7/6 16:55
@Auth : linux超
@File : testCaseNodeB.py
@IDE  : PyCharm
@Motto: Real warriors,dare to face the bleak warning,dare to face the incisive error!
@QQ   : [email protected]
@GROUP: 878565760
------------------------------------
"""
import time
import unittest
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support.wait import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC


class TestSeleniumGrid(unittest.TestCase):

    def setUp(self):
        self.driver = webdriver.Remote(command_executor="http://192.168.1.102:16891/wd/hub",
                                       desired_capabilities={"browserName": "firefox",  # 瀏覽器名稱
                                                             "platform": "WINDOWS"
                                                             })

    def test_grid(self):
        self.driver.get("https://www.baidu.com")
        self.driver.find_element_by_id('kw').send_keys('linux超')
        self.driver.find_element_by_id('su').click()
        WebDriverWait(self.driver, 10). \
            until(EC.visibility_of_element_located((By.XPATH, '//a[text()="https://www.cnblogs.com/"]')))
        page_source = self.driver.page_source
        self.assertIn('linux', page_source)

    def tearDown(self):
        self.driver.quit()


if __name__ == '__main__':
    unittest.main()

執行過程

我們運行hub主機上的代碼然後看一下note節點機器上執行的過程, 並注意看hub主機和note點擊機器cmd終端的輸出結果

執行過程中有一些警告信息,也不知道什麼原因,我還沒找到解決的辦法,但是並不影響測試的執行,到此爲止整個測試環境搭建就完成了

最後

搭建過程需要注意

1.瀏覽器和瀏覽器驅動版本要匹配,且添加到系統環境變量

2.初始化hub和node時的命令不要敲錯,算這次我一共搭過2次環境, 之前2次折騰命令參數就折騰了好久(對一個參數選項不太理解)

3.不要被hub和node機器的ip搞暈,腳本中的要在哪裏運行測試就要配置哪個node節點機器的地址 (command_executor="http://192.168.1.102:16891/wd/hub",而且要主要後面接的/wd/hub是固定的不要寫錯)

需要注意的差不多就這麼多吧, 自己不手動配置一遍你也不會知道究竟會遇到什麼問題

TODO

配置這個測試環境之後,我一直有個疑問,我的代碼只能在一個node上的一個瀏覽器上執行,分佈式分佈式,這樣的話還有啥意義呢?我的理解是應該能同時在不同的node機器上不同的瀏覽器上運行才符合這個概念,所以呢我試着使用python線程併發修改了幾次代碼也沒有成功,試着找資料也沒有解決我這個疑惑,也可能我理解的有問題,不管怎麼樣了,以後有了思路再更新這篇文章吧!

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章