多线程并发测试框架搭建
采用Python编写多线程并发程序,robot framework执行测试用例。
(1)测试用例
在robot framework中,将测试用例打上标签tag,来区分要测试的不同版本的不同浏览器,remote_url为selenium_hub容器的地址,已将该容器的4444端口映射到docker宿主机的5555端口,所以这里直接通过宿主机的5555端口访问hub容器。
测试用例
(2)多线程并发框架
多线程并发框架采用Python编写,程序目录如下:
各文件代码如下:
utils.py:
utils.py
utils.py
multiThreadings.py
multiThreadings.py
callRobot.py
callRobot.py
callRobot.py
run.py
run.py
脚本run.py接收两个参数,第1个参数为要执行的robot测试套件,第2个参数为要执行的robot用例的标签,各标签之间以逗号分隔,有多少个标签,就启动多少个线程来调用robot的pybot命令执行打上相应标签的测试用例。
运行
这里开启2个node节点,一个chrome,一个firefox。cmd下执行脚本,robot测试套件名为TestSuite.txt,执行标签为chromeNode1,firefoxNode1的测试用例:
python run.py TestSuite.txt selenium_node=chromeNode1,firefoxNode1
docker宿主机下,执行docker logs -f selenium_hub,可以查看hub容器的执行日志:
selenium_hub容器日志
通过vnc viwer可视化查看node容器内浏览器的运行情况:
node容器内浏览器运行情况
最终用rebot命令合并各线程生成的测试报告,合并后的报告如下:
合并报告
至此,基于docker的selenium并发web应用UI自动化测试框架搭建完成。之后,自己会再探究将docker容器的创建,启动和停止自动化,实现测试环境的自动化搭建。