在Docker环境使headless实现web自动化持续集成
一、制作镜像
原则:自动化测试基于基础制作镜像
命令:docker run --privileged --name=$1 --net=host -it -v ~:/share zxxxxx-xxxx-snapshot-docker.com.cn/robotframework:2.7.14 bash
修改name为你容器名字,如:name=qinjiaxi
二、配置服务器(单板)SSL证书认证
1、跳转到单板服务器ssl目录
命令:cd /share/ZXxxxx-xxx-xxx/xxx/power/etc/lighttpd/ssl/server
2、修改权限
命令:chmod 755 certmaker.sh
3、运行shell脚本
命令:sh certmaker.sh -i BoardIP
此时的BoardIP是你单板服务器的IP
4、将生成的lighttpd.crt和lighttpd.pem拷贝到单板的/power/etc/lighttpd/ssl/目录下
三、docker下安装chromedriver
1、首先将chromedriver_linux64.zip挂载到/share目录下
2、在share下解压chromedriver_linux64.zip包
命令:unzip chromedriver_linux64.zip
注意事项:由于基于测试的镜像制造的容器是比较基础的,里面比较干净很多软件和包没有安装,在操作时出现command not found属于正常,需要安装相关的包(在安装包前先更新更新安装软件)
前置条件:可以先安装sudo
命令:apt install sudo
有关sudo命令的相关知识自行百度这里不再赘述,只需要知道sudo是一个系统管理指令,允许系统管理员让普通用户可以执行一些或者全部的root命令的一个工具
a、检查默认已安装的软件包(首先检查然后更新,再进行其他操作)
命令:sudo apt update
注:此命令只检查已安装的软件包是否有可用的更新,给出汇总报告,不进行更新
b、更新安装软件
命令:sudo apt upgrade
c、安装其他包
命令:sudo apt install [packagename]
3、移动chromedriver文件
命令:sudo mv -f /share/chromedriver /usr/local/share/chromedriver
4、创建软连接
命令:sudo ln -s /usr/local/share/chromedriver /usr/local/bin/chromedriver
5、创建软连接
命令:sudo ln -s /usr/local/share/chromedriver /usr/bin/chromedriver
6、检查安装是否成功
命令:chromedriver -v
查看到如上的信息表示驱动安装成功
注:在安装过程中会出现各种各样的坑,大部分原因都是由于依赖包的问题导致的,下面简单的介绍几个
安装chromedriver不成功
按照上续安装驱动的步骤来完成chromedriver驱动的安装,也有可能会出现以下安装不成功的报错:
问题分析:出现以上报错的原因是因为chromedriver依赖于libgconf2-4包,所以需要安装此包方能解决问题。
命令:sudo apt install libgconf2-4
如上运行安装命令后,又会出现新的问题,命令行里面提示我们需要强制执行apt-get -f install,执行完后再次运行安装依赖包命令sudo apt install libgconf2-4,最后查看chromedriver版本,看看是否安装成功:
四、docker下安装google-chrome-stable
进入docker根目录下运行以下命令
命令:dpkg -i /share/google-chrome-stable_current_amd64.deb
若以上方法安装失败,按提示安装依赖包,由于逐个安装依赖包比较繁琐,现提供以下简单粗暴方法:
1、修复损坏包
命令:sudo apt-get -f install
2、更新软件源中的所有软件列表
命令:apt-get update
3、更新软件
命令:apt-get upgrade
4、安装google-chrome-stable的deb格式包
命令:dpkg -i /share/google-chrome-stable_current_amd64.deb
注:安装google-chrome-stable的时候也出现过一些情况导致安装不成功,下面进行分享,以免后续需要搭建环境的同事重蹈覆辙。
启动google-chrome报错:
原因:由于google默认要求不能用root用户启动,因此需要换成普通用户
五、配置google-chrome的启动为无沙箱模式
1、确保以下路径存在
路径:/usr/bin/google-chrome
2、查看google-chrome位置
命令:whereis google-chrome
3、启用vim编辑器修改内容
命令:vim /usr/bin/google-chrome
将文末exec -a "$0" "$HERE/chrome" "$@"改为
exec -a "$0" "$HERE/chrome" "$@" --user-data-dir --no-sandbox
六、导入客户端SSL证书到信任列表
1、安装libnss3-tools工具
命令:apt-get install libnss3-tools
2、将平台的enery.crt加入到.pki/nssdb中
a、复制enery.crt文件到ca证书目录下
命令:cp /share/ZXxxxx-xxxx/xxxx/power/etc/lighttpd/ssl/client/energy.crt /usr/local/share/ca-certificates/
b、添加证书到密钥库
命令:keytool -import -keystore ca-certificates -file /usr/local/share/ca-certificates/energy.crt
c、导入ca证书
命令:certutil -d sql:$HOME/.pki/nssdb -A -t "C,," -n "energy" -i /usr/local/share/ca-certificates/energy.crt
在生成证书的时候出现以下问题:
certutil: function failed: security library: bad database.
原因是数据库损坏需要重新建,可执行以下命令解决:
1、在家目录创建.pki/nssdb文件夹
命令:mkdir -p ~/.pki/nssdb
2、修改目录权限
命令:chmod 755 ~/.pki/nssdb
3、生成安全数据库文件
命令:certutil -d sql:$HOME/.pki/nssdb -N
4、列出指定目录下的所有证书
命令:certutil -d sql:$HOME/.pki/nssdb -L
如看到以下信息证明安全数据库建立成功:
5、完成第五步后可以执行导入ca证书命令了
注意:
修改hosts配置信息,打开本地localhost
命令:vim /etc/hosts
七、软件版本信息
1、Robotframeworks
requests (2.18.3)
robotframework (3.0.2)
robotframework-requests (0.4.7)
robotframework-selenium2library (1.8.0)
等一系列的自动化测试相关的环境
2、Chrome for linux
headless chrome=63.0.3239.84(google-chrome-stable_current_63.0.3239.84_amd64)
chromedriver=2.34.522913(chromedriver_linux64_2.34.zip)
八、执行测试
由于采用的是chrome headless无头web自动化测试,因此我们在写测试用例的时候需要注意以下事项:
1、selenium2Library库的openbrowser打开浏览器不能直接使用
2、使用options设置参数单独创建headless浏览器,才能实现无头web测试
采用pybot命令执行测试用例
连接服务器,进入docker容器,使用pybot命令来运行挂载盘中的web自动化测试用例:
命令:pybot -d ./share/headlesstest/TMP -v BOARD_IP:10.112.33.28 -v LANGUAGE:zh_CN.UTF-8 --include web ./share/headlesstest/first_test/test_suite.txt