利用tox打造自動自動化測試框架

什麼是tox

tox官方文檔的第一句話 standardize testing in Python,意思就是說標準化python中的測試,那是否是很適合測試人員來使用呢,咱們來看看他到底是什麼?html

根據官方文檔的解釋,tox是一個管理測試虛擬環境的命令行工具,能夠支持穿件隔離的python環境,在裏面能夠安裝不一樣版本的python解釋器和項目的各類依賴庫,能夠進行自動化測試、打包以及持續集成。python

tox能作什麼

image-20200719215423278

  • 建立測試虛擬環境
  • 運行靜態代碼分析與測試工具
  • 自動化構建包
  • 針對 tox 構建的軟件包運行測試
  • 檢查軟件包是否能在不一樣的 Python 版本/解釋器中順利安裝
  • 統一持續集成(CI)和基於命令行的測試

怎麼配置tox

安裝tox

使用pip install tox安裝,在命令行執行tox -e envname運行指定的測試環境mysql

tox配置

tox的行爲既能夠經過命令行來控制也能夠經過配置文件進行控制,支持有如下三種形式的配置文件redis

  • pyproject.toml
  • tox.ini
  • setup.cfg
# tox (https://tox.readthedocs.io/) is a tool for running tests
# in multiple virtualenvs. This configuration file will run the
# tests suite on all supported python versions. To use it, "pip install tox"
# and then run "tox" from this directory.

[tox]
envlist = py36
skipsdist = True
# 設置pip源和依賴版本
indexserver =
    default = http://mirrors.aliyun.com/pypi/simple/

[testenv]
deps =
    pytest
    records
    pymysql
    jinja2
    requests
    objectpath
    arrow
    pytest-html
    redis
install_command = pip install --trusted-host mirrors.aliyun.com {opts} {packages}
[testenv:dev]
setenv = env = dev
; 告訴tox在每一個測試環境裏運行pytest
commands = pytest --junitxml=junit-{envname}.xml


;只運行廣告相關的測試用例
[testenv:t_a]
setenv = env = dev
commands = pytest -v tests/ad--junitxml=junit-{envname}.xml


;只運行測試環境APP相關測試用例
;只運行APP相關測試用例
[testenv:t_i]
setenv = env = dev
commands = pytest -v tests/ivwen --junitxml=junit-{envname}.xml


[testenv:t1_i]
setenv = env = t1
commands = pytest -v tests/ivwen --junitxml=junit-{envname}.xml


[testenv:pro]
setenv = env = pro
; 經過command line往環境變量裏寫測試仍是線上的標識,config根據標識從環境變量裏去讀取指定文件
; 或者經過插件的形式,可以配置各個環境的文件,根據命令行參數指定把那個文件放入指定讀取目錄
command = pytest


[testenv:smoke]

[pytest]
markers =
    smoke
    get

addopts = -rsxX -l --tb=short --strict
xfail_strict = true
minversion = 3.0
norecursedirs = .* venv src *.egg dist build
testpaths = tests
python_classes = *Test Test* *Suit
junit_family=xunit1

以上配置解釋以下:sql

  • [tox]節點是對tox進行配置

envlist指定環境列表,多個環境用逗號隔開,好比py36,py37數據庫

skipsdist 指定tox在運行過程當中跳過打包環節,由於當前這個項目沒有打包的需求,因此這裏設置爲true,這個和自動化測試框架的設計有關。api

indexserver 指定pip的安裝源框架

  • [testenv]節點是對測試環境進行配置,這個是根測試環境的配置,下面還能夠對不一樣的測試環境進行配置,均可以繼承這個節點

deps 指定項目的python依賴的第三方包工具

install_command 定義pip安裝命令參數測試

  • [testenv:dev]這個節點是定義測試環境,繼承根環境配置

setenv 設置環境變量,在項目中能夠讀取環境變量,從而決定要運行哪一個環境的配置,好比tox -e dev,意思就是說在測試環境運行測試用例,tox -e prod在生產環境運行測試用例

commands 指定pytest的運行方式,其餘環境的節點配置與此類似。

  • [pytest]節點能夠對pytest進行配置
  • addopts 指定pytest的命令行參數
  • xfail_strict 設置預期失敗的case若是經過了,則標記爲失敗
  • minversion 指定tox的最小版本
  • norecursedirs 指定哪些目錄不用遞歸查找測試用例
  • testpaths 指定測試用例的搜索目錄
  • python_classes 指定測試用例的搜索規則

固然以上的配置只是tox一部分,還有不少,關注官方文檔

tox項目實戰

下面咱們以 tox、pytest打造一個自動化測試框架

項目搭建

  • 新建一個api-auto-test文件夾,在文件夾裏添加一個tox.ini文件,輸入上面的配置
  • 再分別新建一個src和tests目錄,src用於存放封裝的一些共有的內容,tests用於存放測試用例
  • src目錄內容以下

image-20200719224646424

ad和biz是對不一樣業務進行的封裝,裏面包括接口調用以及數據庫相關操做

common是各個業務模塊公共的部分,包括請求發送、數據庫連接基礎操做封裝、配置等,主要來看一下config的裏的內容:

class Config:
  '''公共配置'''

class DevConfig(Config):
  '''測試環境配置'''

class ProdConfig(Config):
  '''生產環境配置'''
  
  
# 環境切換  
_MAPPING = {
    'dev': DevConfig,
    't1': T1Config,
    'pro': ProConfig,
}
# 這裏根據tox設置的環境變量,來決定使用哪個環境的配置,從而實現不一樣環境環境的切換
config = _MAPPING.get(os.getenv("env"), DevConfig)
  • 運行測試用例

    tox -e dev

    image-20200719225503001

image-20200719225537242

以上是執行過程以及測試結果,會生成junit.xml格式的測試報告,固然也可使用pytest-html或者其餘測試報告,都很方便。

歡迎你們去 個人博客 瞅瞅,裏面有更多關於測試實戰的內容哦!!
相關文章
相關標籤/搜索