搭建基于Pytest+Selenium+Allure+Gitlab-ci的一鍵自動化測試流程

UI自動化測試框架

框架介紹

python 基于python腳本語言
pytest 最好用的python測試框架
selenium 懂得都懂
allure2 最美的測試報告框架
gitlab-ci 目前我用的cicd工具
linux 最終決定在linux運(yùn)行UI自動化測試用例(效率高)
chromedriver 因為在centos系統(tǒng)運(yùn)行,所以采用無頭瀏覽器,后面介紹配置

搭建流程

centos安裝python3.6環(huán)境

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
進(jìn)入bin目錄,運(yùn)行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/ 下載對應(yīng)的版本
linux查看Chrome版本:
google-chrome --version
修改存放地方:
mv chromedriver /usr/local/bin/
修改權(quán)限:
chmod u+x,o+x /usr/local/bin/chromedriver
輸入 chromedriver -v檢查是否安裝成功,順便檢查版本

安裝測試項目所需依賴包

pip3 install

用test_demo.py調(diào)試一下

因為是無頭瀏覽器模式,所以在driver啟動前要配置Options()
如果運(yùn)行無報錯,則可以放心在linux進(jìn)行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,以下為樣本,實際運(yùn)行中可根據(jù)項目來編寫(關(guān)于gitlab-ci.yml可自行學(xué)習(xí),一旦學(xué)會,終身受用,測試必備cicd知識)

image: harbor.cloudwalk.work/basic/python:3.6  # 依賴所需鏡像

variables:
    CI_RPOJECT_DIR: "/dir/dir" # 設(shè)置git項目路徑

stages:
  - deploy # stages步驟,先后順序

pytest部署:
  stage: deploy
  variables:
    RPOJECT_DIR: "/home/appuser/aps-pytest"  # 設(shè)置服務(wù)器項目路徑
  script:
    # RSA_PRIVATE_KEY 可以在git設(shè)置里添加變量
    # =====配置公鑰=====
    - 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'
    # =====配置公鑰=====
    # 發(fā)送項目
    - scp -P 22121 -o StrictHostKeychecking=no -r  # 執(zhí)行scp發(fā)送項目
    # 遠(yuǎn)程執(zhí)行
    - ssh -p 22121 -o StrictHostKeychecking=no -tt # 執(zhí)行ssh遠(yuǎn)程執(zhí)行pytest命令,allure命令,部署allure-report到靜態(tài)服務(wù)器(也可根據(jù)需求拆分不同步驟)

  tags:
    - k8s_public_centos7.4.1708  # runner配置

最終顯示的allure測試報告

image.png

總結(jié)

以上為整體的自動化測試流程,現(xiàn)在在梳理一遍運(yùn)行流程
1.push代碼到gitlab平臺
2.gitlab通過gitlab-ci.yml自動部署pytest項目到linux
3.gitlab通過gitlab-ci.yml自動遠(yuǎn)程執(zhí)行pytest命令,運(yùn)行測試用例(可在gitlab-ci.yml配置具體運(yùn)行哪些測試用例,功能很強(qiáng)大)
4.gitlab通過gitlab-ci.yml自動遠(yuǎn)程執(zhí)行allure命令,生成測試報告
5.gitlab通過gitlab-ci.yml自動遠(yuǎn)程執(zhí)行部署測試報告到靜態(tài)服務(wù)器

TIPS

1.因為linuxwindows路徑符不同,所以在編寫測試用例時需要根據(jù)系統(tǒng)設(shè)置不同的路徑??梢栽陧椖坷锱袛?,也可以將項目根目錄放在系統(tǒng)環(huán)境變量里,然后調(diào)用os.path.join
2.pytest的項目架構(gòu)后期也會不斷更新出來

更多tips請期待更新


歡迎想了解或者已使用此流程的下方留言,共同探討更優(yōu)的解決方案

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

友情鏈接更多精彩內(nèi)容