搭建基于Pytest+Selenium+Allure+Gitlab-ci的一键自动化测试流程

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测试报告

image.png

总结

以上为整体的自动化测试流程,现在在梳理一遍运行流程
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.因为linuxwindows路径符不同,所以在编写测试用例时需要根据系统设置不同的路径。可以在项目里判断,也可以将项目根目录放在系统环境变量里,然后调用os.path.join
2.pytest的项目架构后期也会不断更新出来

更多tips请期待更新


欢迎想了解或者已使用此流程的下方留言,共同探讨更优的解决方案

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。