全網(wǎng)非常詳細的pytest配置文件
說到配置,大家可能想到的是不經(jīng)常更改的內(nèi)容,比如Django里的settings.py文件,或者我們做自動化的時候,把測試環(huán)境的域名和正式環(huán)境的域名放到一個配置文件里,所有的接口都從這個文件里讀取。這樣,如果有一天,我們的域名變了,我們只需要更改配置里的域名就可以了。pytest里也有幾個配置文件。
- pytest.ini:pytest的主配置文件,可以改變pytest的默認行為,有很多可配置的選項。
- conftest.py:是本地的插件庫,其中的hook函數(shù)和fixture將作用于該文件所在的目錄以及所有子目錄。
- __init__.py:每個測試子目錄都包含該文件時,那么在多個測試目錄中可以出現(xiàn)同名測試文件。
- tox.ini:它與pytest.ini類似,只不過是tox的配置文件,你可以把pytest的配置都寫在tox.ini里,這樣就不用同時使用tox.ini和pytest.ini兩個文件
更改默認命令行選項
我們之前已經(jīng)用過pytest命令行選項了,比如-v/--verbose可以輸出詳細信息,-l/--showlocals可以查看失敗測試用例里堆棧中的局部變量。你也許經(jīng)常要用到某些參數(shù),又不想重復輸入,這時可以使用pytest.ini文件里的addopts設(shè)置。
[pytest] addopts = -rsxX -l --tb=short --strict
--rsxX表示pytest報告所有測試用例被跳過、預計失敗、預計失敗但實際通過的原因。-l表示pytest報告所有失敗測試的堆棧中的局部變量。--tb=short表示簡化堆?;厮菪畔?,只保留文件和行數(shù)。--strict選項表示禁止使用未在配置文件中注冊的標記。
我們有個test_two.py文件,里面有如下代碼
def inc(x): return x + 1 def test_answer(): assert inc(3) == 55 def test_answer1(): assert inc(4) == 5
我們沒有添加如上命令執(zhí)行一遍
再去pytest.int里添加上上面的代碼,在去執(zhí)行一遍
注冊標記來防止拼寫錯誤
在前面我們學過,自定義標記可以簡化測試工作,讓我們用指定的標記運行某個測試子集。但是,標記很容易拼錯,比如把@pytest.mark.smoke拼成@pytest.mark.somke,默認情況下。這不會引起程序錯誤。pytest會以為這是你創(chuàng)建的另一個標記。為了避免拼寫錯誤??梢栽趐ytest.ini文件里注冊標記
[pytest] markers = smoke: Run the smoke test functions for tasks project get: Run the test functions that test tasks.get()
修改test.two.py
import pytest def inc(x): return x + 1 @pytest.mark.smoke def test_answer(): assert inc(3) == 55 @pytest.mark.post def test_answer1(): assert inc(4) == 5
標記注冊好后,可以通過pytest --markers來查看
沒有注冊的標記不會出現(xiàn)在--markers列表里。如果使用了--strict選項,遇到拼寫錯誤的標記或未注冊的標記就會報錯。
pytest.ini里寫如下代碼
[pytest] markers = smoke: Run the smoke test functions for tasks project get: Run the test functions that test tasks.get()
上面的代碼我們在執(zhí)行的時候,把smoke故意寫錯了,也沒有報錯,只是給我們一個警告,只需要我們在ini里注冊下就不會有警告了
在去修改pytest.ini里的代碼
[pytest] addopts = -rsxX -l --tb=short --strict markers = smoke: Run the smoke test functions for tasks project get: Run the test functions that test tasks.get()
我們在ini里加上了addopts = -rsxX -l --tb=short --strict 這句代碼之后,如果我們拼錯了就會報錯
指定pytest的最低版本號
有些功能是隨著pytest版本的更新而加入到里面的,如果我們不想用比較低的版本,可以在配置里指定最低的版本號。
minversion選項可以指定運行測試用例的pytest的最低版本。
[pytest] minversion = 4.0
如果使用了老版本的pytest運行該測試,就會得到一個錯誤信息。
指定pytest忽略某些目錄
pytest執(zhí)行測試搜索時,會遞歸遍歷所有子目錄,包括某些你明知道沒必要遍歷的目錄。遇到這種情況,你可以使用norecurse選項簡化pytest的搜索工作。
norecurse的默認設(shè)置是 .* build dist CVS -darcs {arch}和 *.egg。因為有 .*,所以將虛擬環(huán)境命名為.venv是一個好注意,所有以.(點)開頭的目錄都不會被訪問。如果不是以.(點)開頭,那么需要把它加入norecursedirs里。比如我想忽略test_001目錄
[pytest] norecursedirs = .* venv test_001 *.egg dist build
先來看下目錄結(jié)構(gòu)
test_one.py
import pytest def test_case_01(): assert 0 == 0 def test_case_02(): assert 0 == 0 test_one.py
test_first
import pytest def inc(x): return x + 1 @pytest.mark.smoke def test_answer(): assert inc(3) == 55 @pytest.mark.post def test_answer1(): assert inc(4) == 5 test_first
如果我們不指定norecursedirs就會執(zhí)行djangotest目錄下的所有文件
指定norecursedirs
[pytest] norecursedirs = .* venv test_001 *.egg dist build addopts = -rsxX -l --tb=short --strict markers = smoke: Run the smoke test functions for tasks project get: Run the test functions that test tasks.get() smoek: run post: Run post
也可以指定多個目錄
[pytest] norecursedirs = .* venv test_001 test_002 *.egg dist build
指定測試目錄
norecuredirs告訴pytest哪些路徑不用訪問,而testpaths則指示pytest去哪里訪問。testpaths是一系列相對于根目錄的路徑,用于限定測試用例的搜索范圍。只有在pytest未指定文件目錄參數(shù)或測試用例標識符時,該選項才有作用
如果我們只想執(zhí)行test_001下的測試用例,則可以把test_001放到testpaths里
[pytest] testpaths = test_001
那如果我既指定了testpaths和norecursedirs ,而且兩個是一樣的,結(jié)果會怎樣
[pytest] testpaths = test_001 norecursedirs = .* venv test_001 *.egg dist build
從運行結(jié)果可以看出,如果兩個都指定,且沖突的話,是按照指定的testpaths執(zhí)行的,是不是因為testpaths在上面的原因?qū)е碌模课覀儞Q一下順序
[pytest] norecursedirs = .* venv test_001 *.egg dist build testpaths = test_001
從上面兩次的運行結(jié)果可以看出,如果既指定了testpaths和norecursedirs ,而且兩個是一樣的,則是按照testpaths執(zhí)行的
更改測試搜索的規(guī)則
pytest根據(jù)一定的規(guī)則搜索并運行測試,標準的測試搜索規(guī)則如下。
- 從一個或多個目錄開始查找。你可以在命令行指定文件名或目錄名。如果未指定,則使用當前目錄
- 在該目錄和所有子目錄下遞歸查找測試模塊
- 測試模塊是指文件名為test_*.py或*_test.py的文件
- 在測試模塊中查找以test_開頭的函數(shù)名。
- 查找名字以Test開頭的類,其中,首先篩選掉包含__init__函數(shù)的類,在查找類中以Test_開頭的類方法
以上是標準的測試搜索規(guī)則,你也可以更改它們
python_classes
通常pytest的測試搜索規(guī)則是尋找以Test*開頭的測試類,而且這個類不能有__init__()函數(shù)。但是,如果把測試類命名為<something>Test或<something>Suite怎么辦?python_classes就可以解決這個問題。
[pytest] python_classes = *Test Test* *Suite
這個設(shè)置允許我們像下面這樣給類取名
class DeleteSuite(): def test_delete_1(self): pass def test_delete_2(self): pass
我們修改test_001目錄下的test_onne.py文件
class DeleteSuite(): def test_delete_1(self): assert True def test_delete_2(self): assert False
先不添加python_classes執(zhí)行一下
然后我們添加上python_classes執(zhí)行一下
[pytest] python_classes = *Test Test* *Suite
python_files
像pytest_classes一樣,python_files可以更改默認的測試搜索規(guī)則,而不是僅查找以test_*開頭的文件和以*_test結(jié)尾的文件
假設(shè)你的測試文件統(tǒng)一命名為check_<something>.py。你不必重命名所有的測試文件,只要在pytest.ini文件里增加一行配置即可
[pytest] python_files = test_* *_test check_*
我們將test_one.py改為check_one.py在執(zhí)行
[pytest] python_files = test_* *_test check_* python_classes = *Test Test* *Suite
python_functions
python_functions與之前的兩個設(shè)置類似,它只是用來測試函數(shù)和方法的命名。more規(guī)則以test_*開頭。如果想添加check_*,則只需要添加一行配置
[pytest] python_functions = test_* check_*
修改test_one.py下的代碼
class DeleteSuite(): def check_delete_1(self): assert True def check_delete_2(self): assert False
[pytest] python_functions = test_* check_* python_files = test_* *_test check_* python_classes = *Test Test* *Suite addopts = -rsxX -l -v --tb=short --strict
禁用XPATH
設(shè)置xfail_strict = true將會使那些被標記為@pytest.mark.xfail但實際通過的測試用例也被報告為失敗
[pytest] xfail_strict = true
很難理解是吧?。。『缺?,我給你給個栗子吃
test_one.py代碼如下,可以看到,我們有兩個測試用例,都是標記的預期失敗,但其中一個是會成功,一個是失敗的,我們不加xfail_strict = true來執(zhí)行一下
import pytest @pytest.mark.xfail() def test_answer(): assert 5 == 5 @pytest.mark.xfail() def test_answer1(): assert 5 != 5
可以看到有一個通過了,有一個失敗了,但是我們?nèi)绻氚褬擞洖轭A期失敗的,不管結(jié)果是成功還是失敗都標記為失敗,則要在配置里加xfail_strict = true
[pytest] xfail_strict = true
這樣兩個用例就都是失敗的
到此這篇關(guān)于全網(wǎng)非常詳細的pytest配置文件的文章就介紹到這了,更多相關(guān)pytest配置文件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python+OpenCV圖像處理——圖像二值化的實現(xiàn)
這篇文章主要介紹了Python+OpenCV實現(xiàn)圖像二值化,幫助大家更好的利用python處理圖片,感興趣的朋友可以了解下2020-10-10在python中用print()輸出多個格式化參數(shù)的方法
今天小編就為大家分享一篇在python中用print()輸出多個格式化參數(shù)的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-07-07