跨浏览器执行测试适用场景:
不同平台(Windows,Mac等),不同浏览器(firefox,ie,chrome等)执行测试,主要用于测试web产品的兼容性
远程执行测试适用场景:
并行执行测试脚本,从而缩短测试总耗时
测试环境搭建:
要使用Grid2,需要下载selenium-server-standalone,可在我的资源里下载,下载地址:https://download.youkuaiyun.com/download/guaishounan/11223649,其次,我们需要保证电脑有java环境(jdk的安装比较简单,这里不做介绍,读者可自行百度),这样才能去启动hub和node!
1.启动hub:
下载完成后,cmd命令行切换到selenium-server-standalone所在位置,执行命令java -jar selenium-server-standalone-3.141.59.jar -role hub启动hub,hub主要用来管理各个代理节点的注册和状态信息,并且接受远程客户端代码的请求调用,然后把请求的命令再转发给代理节点来执行。
2.启动node节点:
启动ie浏览器节点cmd命令行示例:
java -Dwebdriver.ie.driver="D:\IEDriverServer.64.exe" -jar D:\selenium-server-standalone-3.141.59.jar -role webdriver -browser "browserName=internet explorer,version=11,maxinstance=1,platform=WINDOWS" -hubHost localhost -port 5555,其它浏览器节点的启动方式与此类似,只需要更改浏览器驱动的名称,浏览器名称,浏览器版本和运行平台,端口号等即可
3.监控节点:
启动hub和node后,在浏览器输入 http://"hub的ip":"hub的端口,默认为4444"/grid/console,显示如下画面,表示hub和node启动成功:
4.编写测试脚本,以python为例,测试在不同的浏览器上使用百度搜索笔者的博客:
import sys
import time
import warnings
from selenium import webdriver
import unittest
class SearchBaidu(unittest.TestCase):
PLATFORM = 'WINDOWS'
BROWSER = 'internet explorer'#当用户在命令行无输入时使用的默认浏览器
#BROWSER = 'firefox'
# BROWSER = 'chrome'
# BROWSER = 'MicrosoftEdge'
def setUp(self):
warnings.filterwarnings("ignore")
desired_caps = {}
desired_caps['platform'] = self.PLATFORM
desired_caps['browserName'] = self.BROWSER
try:
wd = webdriver.Remote(command_executor='http://192.168.1.168:4444/wd/hub', desired_capabilities=desired_caps)
self.wd = wd
except:
wd = self.wd
wd.quit()
def testSearchBaidu(self):
try:
wd = self.wd
wd.get("https://www.baidu.com")
wd.implicitly_wait(5)
wd.maximize_window()
time.sleep(2)
wd.find_element_by_id("kw").send_keys("guaishounan的博客")
wd.find_element_by_id("su").click()
except:
wd = self.wd
wd.quit()
def tearDown(self):
wd = self.wd
time.sleep(3)
wd.quit()
if __name__ == '__main__':
if len(sys.argv) > 1:
SearchBaidu.BROWSER = sys.argv.pop()
SearchBaidu.PLATFORM = sys.argv.pop()
unittest.main(verbosity=2)
5.切换到测试脚本所在位置,cmd命令行传入对应的平台名称和浏览器名称执行测试:
执行结果如图所示:
以上就是远程跨浏览器测试的一个简单实现,细心的读者应该会发现,测试脚本的健壮性很差!比如我忘记输测试平台的名称或者浏览器名称输错,就会导致异常发生,测试无法执行,如下图所示:
因此,我们需要在测试脚本中加入判断和异常处理,提高测试脚本的健壮性,具体实现我会在接下来的博文里以java语言为例为大家展示!