UI自动化测试框架
框架介绍
python
基于python脚本语言
pytest
最好用的python测试框架
selenium
懂得都懂
allure2
最美的测试报告框架
gitlab-ci
目前我用的cicd工具
linux
最终决定在linux运行UI自动化测试用例(效率高)
chromedriver
因为在centos系统运行,所以采用无头浏览器,后面介绍配置
搭建流程
centos安装python3.6环境
centos7自带python2.7,要另外搭建一套python3.6
yum install -y openssl-devel bzip2-devel expat-devel gdbm-devel readline-devel sqlite-devel
wget https://www.python.org/ftp/python/3.6.5/Python-3.6.5.tgz
tar -xzvf Python-3.6.5.tgz
cd Python-3.6.5
./configure --prefix=/usr/local/python
Make
make install
ln -s /usr/local/python/bin/python3.6 /usr/bin/python3
ln -s /usr/local/python/bin/pip3.6 /usr/bin/pip3
python3 -V 检验是否成功
pip3 -V 检验是否成功
安装allure2
https://dl.bintray.com/qameta/generic/io/qameta/allure/allure/2.7.0/allure-2.7.0.zip
下载allure2.7,上传到linux
进入bin目录,运行bash allure即可成功
安装chrome和chromedriver
chrome-linux版(需梯子,也可以提前下好上传上去)
wget https://dl.google.com/linux/direct/google-chrome-stable_current_x86_64.rpm
yum install ./google-chrome-stable_current_x86_64.rpm
chromedriver-linux版
去https://npm.taobao.org/mirrors/chromedriver/ 下载对应的版本
linux查看Chrome版本:
google-chrome --version
修改存放地方:
mv chromedriver /usr/local/bin/
修改权限:
chmod u+x,o+x /usr/local/bin/chromedriver
输入 chromedriver -v检查是否安装成功,顺便检查版本
安装测试项目所需依赖包
pip3 install
用test_demo.py调试一下
因为是无头浏览器模式,所以在driver启动前要配置Options()
如果运行无报错,则可以放心在linux进行UI自动化测试了
python3 -m pytest test_demo.py
options = Options()
options.add_argument("--disable-notifications")
options.add_argument("--disable-infobars")
options.add_argument("--mute-audio")
options.add_argument('--disable-dev-shm-usage')
options.add_argument('--no-sandbox')
options.add_experimental_option('excludeSwitches', ['enable-automation'])
prefs = {"profile.managed_default_content_settings.images": 2}
options.add_experimental_option("prefs", prefs)
options.add_argument("--headless")
options.add_argument('--disable-gpu')
driver = webdriver.Chrome(executable_path="/user/chromedriver", options=options) #executable_path更改为你的chromedriver的路径
driver.open("www.baidu.com")
开始部署你的pytest项目
基于公司搭建的gitlab代码管理平台,所以我的pytest项目也放在gitlab上,天然支持gitlab-ci,所以没有采用jenkins的pipeline作为cicd工具。
编写gitlab-ci.yml,以下为样本,实际运行中可根据项目来编写(关于gitlab-ci.yml可自行学习,一旦学会,终身受用,测试必备cicd知识)
image: harbor.cloudwalk.work/basic/python:3.6 # 依赖所需镜像
variables:
CI_RPOJECT_DIR: "/dir/dir" # 设置git项目路径
stages:
- deploy # stages步骤,先后顺序
pytest部署:
stage: deploy
variables:
RPOJECT_DIR: "/home/appuser/aps-pytest" # 设置服务器项目路径
script:
# RSA_PRIVATE_KEY 可以在git设置里添加变量
# =====配置公钥=====
- eval $(ssh-agent -s)
- echo "$RSA_PRIVATE_KEY"
- echo "$RSA_PRIVATE_KEY" > deploy.key
- chmod 700 deploy.key
- ssh-add deploy.key
- mkdir -p ~/.ssh
- '[[ -f /.dockerenv ]] && echo -e "Host *\n\tStrictHostKeyChecking no\n\n" > ~/.ssh/config'
# =====配置公钥=====
# 发送项目
- scp -P 22121 -o StrictHostKeychecking=no -r # 执行scp发送项目
# 远程执行
- ssh -p 22121 -o StrictHostKeychecking=no -tt # 执行ssh远程执行pytest命令,allure命令,部署allure-report到静态服务器(也可根据需求拆分不同步骤)
tags:
- k8s_public_centos7.4.1708 # runner配置
最终显示的allure测试报告
总结
以上为整体的自动化测试流程,现在在梳理一遍运行流程
1.push代码到gitlab平台
2.gitlab通过gitlab-ci.yml自动部署pytest项目到linux
3.gitlab通过gitlab-ci.yml自动远程执行pytest命令,运行测试用例(可在gitlab-ci.yml配置具体运行哪些测试用例,功能很强大)
4.gitlab通过gitlab-ci.yml自动远程执行allure命令,生成测试报告
5.gitlab通过gitlab-ci.yml自动远程执行部署测试报告到静态服务器
TIPS
1.因为linux
和windows
路径符不同,所以在编写测试用例时需要根据系统设置不同的路径。可以在项目里判断,也可以将项目根目录放在系统环境变量里,然后调用os.path.join
2.pytest的项目架构后期也会不断更新出来
更多tips请期待更新
欢迎想了解或者已使用此流程的下方留言,共同探讨更优的解决方案