python單測(cè)框架之pytest常見用法
單測(cè)框架的作用
- 測(cè)試發(fā)現(xiàn):從多個(gè)文件中尋找測(cè)試用例。
- 測(cè)試執(zhí)行:按照一定順序去執(zhí)行并且生成結(jié)果。
- 測(cè)試斷言:判斷最終結(jié)果與實(shí)際結(jié)果的差異。
- 測(cè)試報(bào)告:統(tǒng)計(jì)測(cè)試進(jìn)度、耗時(shí)、通過率,生成測(cè)試報(bào)告。
pytest簡(jiǎn)介
pytest是python的單測(cè)框架,使用靈活,插件豐富,以下是pytest常用的插件
- pytest
- pytest-html:生成html測(cè)試報(bào)告插件
- pytest-xdist:多線程執(zhí)行用例插件
- pytest-ordering:自定義用例順序插件
- pytest-rerunfailures:失敗重跑插件
- allure-pytest:生成allure美觀測(cè)試報(bào)告插件
pip install 就行,只有有這些插件,下面的某些命令行才生效
pytest默認(rèn)規(guī)則
- 模塊名必須以test_開頭或者_(dá)test結(jié)尾
- 類名必須以Test開頭
- 測(cè)試方法必須以test開頭
- pytest用例運(yùn)行順序默認(rèn)從上到下(代碼中可以使用裝飾器@pytest.mark.run(order=1)來指定執(zhí)行順序)
使用pytest.ini文件可以修改默認(rèn)規(guī)則
pytest的運(yùn)行方式
主函數(shù)模式
import pytest if __name__ == '__main__': pytest.main(["-vs", "./test_demo/test_demo1.py"])
這樣就可以運(yùn)行所有用例
命令行模式
pytest -vs ./test_demo/test_demo1.py
參數(shù)詳解
- -s:輸出調(diào)試的信息
- -v:表示詳細(xì)的方式輸出
- ./test_demo/test_demo1.py表示運(yùn)行指定模塊,相對(duì)路徑表示
- ./test_demo/test_demo1.py::TestCase1::test_case1 nodeid表示,代表運(yùn)行./test_demo/test_demo1.py模塊下的TestCase1類的test_case1 方法
- -n分布式運(yùn)行測(cè)試用例,-n num,參數(shù)num代表幾個(gè)線程運(yùn)行用例
- –reruns=2表示用例失敗重跑2次,常用于一些不穩(wěn)定的用例,如web自動(dòng)化
- -x只要有一個(gè)用例報(bào)錯(cuò),那么就會(huì)停止
- –maxfail=2,有2個(gè)用例失敗就會(huì)停止
- -k根據(jù)測(cè)試用例部分字符串指定測(cè)試用例,如 -k “ao”,代表會(huì)執(zhí)行帶有ao名稱的字符串
讀取pytest.ini配置文件運(yùn)行
不論是主函數(shù)模式還是命令行模式都會(huì)讀取這個(gè)配置文件,該文件需要使用gbk編碼,下面是這個(gè)配置文件的例子
[pytest] # 命令行參數(shù),用空格分隔 addopts = -vs # 測(cè)試用例文件夾,可以自己配置 testpaths = ./test_demo # 配置測(cè)試搜索的模塊文件名稱 python_files = test*.py # 配置測(cè)試搜索的類名 python_classes = Test* # 配置搜索的函數(shù)名 python_functions = test
分組執(zhí)行
定義三個(gè)組,冒煙:smoke,用戶管理:user_manager,作業(yè)管理:worker_manager
目前有幾個(gè)用例給加個(gè)分組的裝飾器
import pytest class TestDemo: @pytest.mark.somke def test_case1(self): print("1") @pytest.mark.user_manage def test_case2(self): print("2") @pytest.mark.worker_manage def test_case3(self): print("3")
配置文件中加入分組信息
markers = smoke:冒煙測(cè)試 user_manage:用戶管理 worker_manage:作業(yè)管理
運(yùn)行
運(yùn)行多組
import pytest if __name__ == '__main__': pytest.main(["-vs", "-m smoke or usermanage"])
運(yùn)行單組
import pytest if __name__ == '__main__': pytest.main(["-vs", "-m smoke"])
忽略執(zhí)行
無條件忽略
直接使用裝飾器@pytest.mark.skip(reason=“原因填寫”)
有條件忽略
使用裝飾器@pytest.mark.skipif(條件, 原因)
例子:
import pytest class TestDemo: age = 18 @pytest.mark.smoke def test_case1(self): print("1") @pytest.mark.usermanage @pytest.mark.skipif(age < 18, "未成年") def test_case2(self): print("2") @pytest.mark.workermanage @pytest.mark.skip(reason="原因填寫") def test_case3(self): print("3")
pytest中的前后置處理
為什么需要前后置?比如執(zhí)行用例前需要做一些準(zhǔn)備工作,比如打開瀏覽器,在執(zhí)行用例后需要一些后置工作,比如關(guān)閉瀏覽器
模塊級(jí)別
在每個(gè)模塊執(zhí)行前會(huì)調(diào)用setup_module方法,在每個(gè)模塊執(zhí)行后會(huì)使用teardown_module方法。
例子:
import pytest def setup_module(): print("模塊用例前執(zhí)行") def teardown_module(): print("模塊用例后執(zhí)行") class TestDemo: def test_case1(self): print("1") def test_case2(self): print("2") def test_case3(self): print("3") class TestDemo2: def test_case4(self): print("4")
結(jié)果:
test_demo/test_demo2.py::TestDemo::test_case1 模塊用例前執(zhí)行 1 PASSED test_demo/test_demo2.py::TestDemo::test_case2 2 PASSED test_demo/test_demo2.py::TestDemo::test_case3 3 PASSED test_demo/test_demo2.py::TestDemo2::test_case4 4 PASSED模塊用例后執(zhí)行
類級(jí)別
類級(jí)別函數(shù) setup_class/teardown_class 對(duì)類有效,位于類中,在測(cè)試類中前后調(diào)用一次。
class TestDemo: def setup_class(self): print("類級(jí)別前置") def test_case1(self): print("1") def test_case2(self): print("2") def test_case3(self): print("3") def teardown_class(self): print("類級(jí)別后置")
test_demo/test_demo2.py::TestDemo::test_case1 模塊用例前執(zhí)行 類級(jí)別前置 1 PASSED test_demo/test_demo2.py::TestDemo::test_case2 2 PASSED test_demo/test_demo2.py::TestDemo::test_case3 3 PASSED類級(jí)別后置 模塊用例后執(zhí)行
方法級(jí)別
方法級(jí)別函數(shù) setup_method/teardown_method和setup/teardown對(duì)類有效,也位于類中,這兩個(gè)效果一樣,在測(cè)試類中每個(gè)測(cè)試方法前后調(diào)用一次。
class TestDemo: def setup_method(self): print("方法級(jí)別前置") def test_case1(self): print("1") def test_case2(self): print("2") def test_case3(self): print("3") def teardown_method(self): print("方法級(jí)別后置")
test_demo/test_demo3.py::TestDemo::test_case1 方法級(jí)別前置 PASSED方法級(jí)別后置 test_demo/test_demo3.py::TestDemo::test_case2 方法級(jí)別前置 PASSED方法級(jí)別后置 test_demo/test_demo3.py::TestDemo::test_case3 方法級(jí)別前置 PASSED方法級(jí)別后置
部分用例的前后置 pytest.fixture裝飾器
import pytest @pytest.fixture(scope="function", params=["1", "2", "3"], autouse=False, ids=None, name="new_name") def my_feature(request): i = request.param print("前置") yield i print("后置") class TestDemo: def test_case1(self, new_name): print(new_name) print("1")
結(jié)果
test_demo/test_demo4.py::TestDemo::test_case1[1] 前置
1
1
PASSED后置test_demo/test_demo4.py::TestDemo::test_case1[2] 前置
2
1
PASSED后置test_demo/test_demo4.py::TestDemo::test_case1[3] 前置
3
1
PASSED后置
- scope:表示作用域
- params:表示參數(shù)化,與yield使用會(huì)調(diào)用len(params)次用例,如例子所示,一般用于數(shù)據(jù)驅(qū)動(dòng)
- autouse:默認(rèn)使用,一般設(shè)置為false
- ids:params參數(shù)化時(shí),給每個(gè)參數(shù)起名字
- name:給該方法取別名
pytest.fixture+conftest
fixture為session級(jí)別是可以跨.py模塊調(diào)用的,也就是當(dāng)我們有多個(gè).py文件的用例的時(shí)候,如果多個(gè)用例只需調(diào)用一次fixture,那就可以設(shè)置為scope=“session”,并且寫到conftest.py文件里。
conftest.py文件名稱時(shí)固定的,pytest會(huì)自動(dòng)識(shí)別該文件。放到項(xiàng)目的根目錄下就可以全局調(diào)用了,如果放到某個(gè)package下,那就在改package內(nèi)有效。
例子:
在包下創(chuàng)建conftest.py,注意,該配置只在本包生效
和之前一樣使用
結(jié)果還是和之前一樣。
pytest生成測(cè)試報(bào)告
pytest-html插件生成報(bào)告
pytest -vs --html ./report/report.html
參數(shù)化與數(shù)據(jù)驅(qū)動(dòng)
主要用的裝飾器是@pytest.mark.parametrize(argnames, argvalues)
不帶名字?jǐn)?shù)據(jù)驅(qū)動(dòng)
import pytest class TestDemo: @pytest.mark.parametrize("args",[(4399, 'AAAA'), (2012, 'BBBB')]) def test_case1(self, args): print(args)
結(jié)果:
test_demo/test_demo4.py::TestDemo::test_case1[args0] (4399, ‘AAAA')
PASSED
test_demo/test_demo4.py::TestDemo::test_case1[args1] (2012, ‘BBBB')
PASSED 帶名字的數(shù)據(jù)驅(qū)動(dòng)
import pytest class TestDemo: @pytest.mark.parametrize("arg1,arg2", [(4399, 'AAAA'), (2012, 'BBBB')]) def test_case1(self, arg1, arg2): print(arg1, arg2)
結(jié)果:
test_demo/test_demo4.py::TestDemo::test_case1[4399-AAAA] 4399 AAAA
PASSED
test_demo/test_demo4.py::TestDemo::test_case1[2012-BBBB] 2012 BBBB
PASSED
到此這篇關(guān)于python單測(cè)框架之pytest慣用法的文章就介紹到這了,更多相關(guān)python單測(cè)框架pytest內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Pytest使用logging模塊寫日志的實(shí)例詳解
- pytest測(cè)試框架+allure超詳細(xì)教程
- pytest官方文檔解讀之安裝和使用插件的方法
- pytest使用@pytest.mark.parametrize()實(shí)現(xiàn)參數(shù)化的示例代碼
- Pytest執(zhí)行unittest TestSuite(測(cè)試套件)的實(shí)現(xiàn)方法
- 詳解Pytest測(cè)試用例的執(zhí)行方法
- Python pytest裝飾器總結(jié)(實(shí)例詳解)
- 詳解pytest實(shí)現(xiàn)mark標(biāo)記功能詳細(xì)介紹
- pytest-sugar?執(zhí)行過程中顯示進(jìn)度條的腳本分享
相關(guān)文章
Python實(shí)現(xiàn)自動(dòng)訪問網(wǎng)頁(yè)的例子
今天小編就為大家分享一篇Python實(shí)現(xiàn)自動(dòng)訪問網(wǎng)頁(yè)的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-02-02OpenCV 使用imread()函數(shù)讀取圖片的六種正確姿勢(shì)
這篇文章主要介紹了OpenCV 使用imread()函數(shù)讀取圖片的六種正確姿勢(shì),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07python數(shù)據(jù)處理和數(shù)據(jù)清洗的示例詳解
數(shù)據(jù)清洗是指發(fā)現(xiàn)并糾正數(shù)據(jù)文件中可識(shí)別的錯(cuò)誤的最后一道程序,包括檢查數(shù)據(jù)一致性,處理無效值和缺失值等,數(shù)據(jù)清洗與處理的目的是提高數(shù)據(jù)的質(zhì)量,提高實(shí)驗(yàn)結(jié)果的可靠度,本文給大家介紹了python數(shù)據(jù)處理和數(shù)據(jù)清洗的示例,需要的朋友可以參考下2024-08-08Python實(shí)現(xiàn)列表轉(zhuǎn)換成字典數(shù)據(jù)結(jié)構(gòu)的方法
這篇文章主要介紹了Python實(shí)現(xiàn)列表轉(zhuǎn)換成字典數(shù)據(jù)結(jié)構(gòu)的方法,結(jié)合實(shí)例形式分析了Python數(shù)值類型轉(zhuǎn)換的相關(guān)技巧,需要的朋友可以參考下2016-03-03關(guān)于如何把Python對(duì)象存儲(chǔ)為文件的方法詳解
本文將給大家介紹如何把Python對(duì)象存儲(chǔ)為文件的方法,pickle可以用二進(jìn)制表示并讀寫python數(shù)據(jù),這個(gè)功能并不安全,如果把一個(gè)pickle暴露給別人,有被植入惡意程序的風(fēng)險(xiǎn),文中通過代碼給大家講解的非常詳細(xì),需要的朋友可以參考下2024-01-01利用Pandas讀取表格行數(shù)據(jù)判斷是否相同的方法
這篇文章主要給大家介紹了關(guān)于利用Pandas讀取表格行數(shù)據(jù)判斷是否相同的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03Pycharm Terminal 與Project interpreter 安裝
本文主要介紹了Pycharm Terminal 與Project interpreter 安裝包不同步問題解決,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-02-02Python flask框架實(shí)現(xiàn)瀏覽器點(diǎn)擊自定義跳轉(zhuǎn)頁(yè)面
這篇文章主要介紹了Python flask框架實(shí)現(xiàn)瀏覽器點(diǎn)擊自定義跳轉(zhuǎn)頁(yè)面,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-06-06