Pytest
的入門操作使用
pytest
特點(diǎn):
-
非常容易上手,入門簡單,文檔豐富,文檔中有很多實(shí)例可以參考
-
能夠支持簡單的單元測試和復(fù)雜的功能測試
-
支持參數(shù)化
-
執(zhí)行測試過程中可以將某些測試跳過(skip),或者對某些預(yù)期失敗的case標(biāo)記成失敗
-
支持重復(fù)執(zhí)行(rerun)失敗的 case
-
支持運(yùn)行由 nose, unittest 編寫的測試 case
-
可生成
html
報(bào)告 -
方便的和持續(xù)集成工具
jenkins
集成 -
可支持執(zhí)行部分用例
-
具有很多第三方插件,并且可以自定義擴(kuò)展
安裝
直接執(zhí)行 如下命令即可安裝pytest
pip install pytest
我們還需要產(chǎn)生測試報(bào)表,所以要安裝一個(gè)第三方插件 pytest-html
,執(zhí)行如下命令安裝
pip install pytest-html
def func(x):
return x + 3
def test_answer():
assert func(3) == 6
class TestClass:
def test_01(self):
print('n用例01')
assert 1 == 1
def test_02(self):
print('n用例02')
assert 2 == 2
def test_03(self):
print('n用例03')
assert 3 == 2
然后,cmd
進(jìn)入當(dāng)前文件目錄,直接執(zhí)行
pytest
PS D:Lemonpy45webatuotestpytest_learn> pytest .test_learn01.py
========================================================== test session starts ==========================================================
platform win32 -- Python 3.9.7, pytest-6.2.5, py-1.10.0, pluggy-1.0.0
rootdir: D:Lemonpy45webatuotestpytest_learn
plugins: allure-pytest-2.9.43, anyio-3.3.2, html-3.1.1, metadata-1.11.0
collected 4 items
test_learn01.py ...F [100%]
=============================================================== FAILURES ================================================================
___________________________________________________________ TestClass.test_03 ___________________________________________________________
self = <test_learn01.TestClass object at 0x0000023FFB6743D0>
def test_03(self):
print('n用例03')
> assert 3 == 2
E assert 3 == 2
test_learn01.py:27: AssertionError
--------------------------------------------------------- Captured stdout call ----------------------------------------------------------
用例03
======================================================== short test summary info ========================================================
FAILED test_learn01.py::TestClass::test_03 - assert 3 == 2
====================================================== 1 failed, 3 passed in 0.21s ======================================================
PS D:Lemonpy45webatuotestpytest_learn>
注意:
-
如果只執(zhí)行
pytest
,會(huì)查找當(dāng)前目錄及其子目錄下以test_*.py 或 *_test.py
文件,找到文件后,在文件中找到以 test 開頭函數(shù)并執(zhí)行 -
如果只想執(zhí)行某個(gè)文件,可以
pytest start.py
-
加上-q,就是顯示簡單的結(jié)果:
pytest -q start.py
-
如果我們希望 顯示測試代碼中print的內(nèi)容,因?yàn)檫@些打印語句在調(diào)試代碼時(shí)很有用,可以加上命令行參數(shù) -s
如下
pytest -s
-
如果我們希望得到更詳細(xì)的執(zhí)行信息,包括每個(gè)測試類、測試函數(shù)的名字,可以加上參數(shù) -v,這個(gè)參數(shù)可以和 -s 合并為 -sv
如下
pytest -sv
-
為了防止
pytest
到其他目錄中找測試用例項(xiàng),執(zhí)行測試時(shí),我們可以在命令行加上目標(biāo)目錄 cases ,就是這樣pytest cases
pytest運(yùn)行方式
測試類主函數(shù)模式
# test_abc.py
import pytest # 引入pytest包
def test_a(): # test開頭的測試函數(shù)
print("------->test_a")
assert 1 # 斷言成功
def test_b():
print("------->test_b")
assert 0 # 斷言失敗
if __name__ == '__main__':
# pytest.main("-s test_abc.py") 早期版本是這樣的執(zhí)行的
pytest.main(["-s", "test_abc.py"]) # 調(diào)用pytest的main函數(shù)執(zhí)行測試
命令行模式運(yùn)行
# pytest 文件路徑/測試文件名
pytest ./test_abc.py
Pytest
用例的設(shè)計(jì)原則
用Pytest
寫用例時(shí)候,一定要按照下面的規(guī)則去寫,否則不符合規(guī)則的測試用例是不會(huì)執(zhí)行的
-
文件名以
test_*.py
文件和*_test.py
-
以 test_ 開頭的函數(shù)
-
以 Test 開頭的類,不能包含
__init
__ 方法 -
所有的包 package 必須要有
__init__.py
文件
Pytest
之并發(fā)執(zhí)行
在Pytest測試框架中提供了pytest-xdist可以并發(fā)執(zhí)行測試用例,來提升測試用例的執(zhí)行速度。通常的情況下,測試用例的執(zhí)行都是依據(jù)一定的規(guī)則來按順序進(jìn)行執(zhí)行,這樣的結(jié)果是每次執(zhí)行的時(shí)候有的資源就只能被一個(gè)測試用例占用,而達(dá)不到測試用例執(zhí)行的時(shí)候資源的共享,插件pytest-xdist插件可以很好的解決這個(gè)問題,一方面資源達(dá)到共享,基于第一點(diǎn)的考慮,也就達(dá)到了第二點(diǎn)的提升了測試執(zhí)行的效率。
-
安裝pytest-xdist插件 pip install pytest-xdist
-
使用 pytest -n auto 默認(rèn)自動(dòng)檢查系統(tǒng)cpu個(gè)數(shù),然后進(jìn)行并發(fā)
-
也可以指定并發(fā)數(shù) pytest -n 2 即并發(fā)數(shù)2執(zhí)行
pytest的重復(fù)執(zhí)行
安裝:pip3 install pytest-repeat
命令行方式
使用–count命令行選項(xiàng)來指定您要運(yùn)行一個(gè)或多個(gè)測試的次數(shù):
pytest --count = 10 test.py
代碼方式
如果要在代碼中將測試標(biāo)記為重復(fù)多次,則可以使用
# @pytest.mark.repeat(count)裝飾器:
import pytest
@pytest.mark.repeat(3)
def test_example():
print("執(zhí)行成功")
重復(fù)測試直到失敗
有時(shí)候,功能模塊不穩(wěn)定,會(huì)存在一些錯(cuò)誤,可以將 -x 與 pytest-repeat 一起用,強(qiáng)制運(yùn)行器在第一次測試失敗時(shí)停止
py.test --count=1000 -x test.py
repeat-scope的使用
命令行參數(shù)
作用:能夠覆蓋默認(rèn)的測試用例執(zhí)行順序,相似fixture的scope參數(shù)
-
function:默認(rèn),范圍針對每一個(gè)用例重復(fù)執(zhí)行,再執(zhí)行下一個(gè)用例
-
class:以class為用例集合單位,重復(fù)執(zhí)行class里面的用例,再執(zhí)行下一個(gè)
pytest -s --count=2 --repeat-scope=class test_Class.py
-
module:以模塊為單位,重復(fù)執(zhí)行模塊里面的用例,再執(zhí)行下一個(gè)
pytest -s --count=2 --repeat-scope=moudle test_Class.py
-
session:重復(fù)整個(gè)測試會(huì)話,即全部測試用例的執(zhí)行一次,而后再執(zhí)行第二次
產(chǎn)生報(bào)告
前面在安裝pytest
,我們也安裝了 pytest-html
插件,這個(gè)插件就是用來產(chǎn)生測試報(bào)告的。
要產(chǎn)生報(bào)告,在命令行加上 參數(shù) --html=report.html --self-contained-html
,如下
pytest cases --html=report.html --self-contained-html
這樣就會(huì)產(chǎn)生名為 report.html
的測試報(bào)告文件,可以在瀏覽器中打開