今天就跟大家聊聊有關如何在python中配置pytest框架,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據(jù)這篇文章可以有所收獲。
成都創(chuàng)新互聯(lián)公司專注于成都網(wǎng)站建設、網(wǎng)站設計、網(wǎng)頁設計、網(wǎng)站制作、網(wǎng)站開發(fā)。公司秉持“客戶至上,用心服務”的宗旨,從客戶的利益和觀點出發(fā),讓客戶在網(wǎng)絡營銷中找到自己的駐足之地。尊重和關懷每一位客戶,用嚴謹?shù)膽B(tài)度對待客戶,用專業(yè)的服務創(chuàng)造價值,成為客戶值得信賴的朋友,為客戶解除后顧之憂。pytest執(zhí)行用例命令行參數(shù)
--collect-only:羅列出所有當前目錄下所有的測試模塊,測試類及測試函數(shù)
--tb=style:屏蔽測試用例執(zhí)行輸出的回溯信息,可以簡化用例失敗時的輸出信息。style可以是 on,line,short,具體區(qū)別請自行體驗
--lf:當一次用例執(zhí)行完成后,如果其中存在失敗的測試用例,那么我們可以使用此命令重新運行失敗的測試用例
我們第一次執(zhí)行用例,會看到有2個用例失敗
我們使用--lf參數(shù)再次運行用例,可以發(fā)現(xiàn)只有之前失敗的兩個用例重新執(zhí)行了一次
--ff:如果上次測試用例出現(xiàn)失敗的用例,當使用--ff后,失敗的測試用例會首先執(zhí)行,剩余的用例也會再次執(zhí)行一次
小結
以上就是命令行運行測試用例時經常使用到的參數(shù),這些參數(shù)不僅可以單獨使用,也可以組合一起使用,后期還會涉及到使用fixture時的一些命令,現(xiàn)在不需要了解。你可以使用--help來查看一些命令幫助信息!
pytest收集測試用例的規(guī)則
1)從一個或者多個目錄開始查找,你可以在命令行指定文件或者目錄,如果未指定那么從當前目錄開始收集用例
2)在該目錄和所有子目錄下遞歸查找測試模塊
3)測試模塊是指文件名為test_*.py或者*_test.py的文件
4)在測試模塊中查找以test_開頭的函數(shù)
5)查找名字以Test開頭的類。其中首先篩選掉包含__init__()函數(shù)的類,再查找類中以Test_開頭的類方法
規(guī)則驗證
現(xiàn)在我們就依次演示pytest搜索測試用例的過程
首先我們按照以下目錄結構新建一個項目
每個文件編寫如下代碼(我們只是為了驗證規(guī)則,所以用例些的很簡單,實際項目不會存在這樣簡單的用例)
test_測試模塊1.py
# 測試函數(shù) def test_2(): assert 1 == 1 # 普通函數(shù) def func_2(): print('普通函數(shù)') # 測試類 class TestClass_2(object): # 測試函數(shù) def test_class_3(self): assert 1 == 1 # 普通函數(shù) def func_class_3(self): assert 1 == 1 # 普通類 class NoTestClass_2(object): # 測試函數(shù) def test_class_4(self): assert 1 == 1 # 普通函數(shù) def func_class_4(self): assert 1 == 1
test_測試模塊2.py
# 測試函數(shù) def test_1(): assert 1==1 # 普通函數(shù) def func_1(): print('普通函數(shù)') # 測試類 class TestClass_1(object): # 測試函數(shù) def test_class_1(self): assert 1==1 # 普通函數(shù) def func_class_1(self): assert 1==1 # 普通類 class NoTestClass_1(object): # 測試函數(shù) def test_class_2(self): assert 1 == 1 # 普通函數(shù) def func_class_2(self): assert 1 == 1
測試用例.py
# 測試函數(shù) def test_one(): assert 1==1 # 普通函數(shù) def func(): assert 1==1
代碼分析
我們現(xiàn)在根據(jù)理論分析并結合代碼,可以大致計算出,從項目根目錄執(zhí)行用例,應該會執(zhí)行4條有效測試用例!
我們在項目根目錄下執(zhí)行pytest --collect-only看下情況,可以發(fā)現(xiàn) 搜索了test_測試模塊1和test_測試模塊2文件,并包括TestClass_2和TestClass_1類及內部test_class_3和test_class_1 和外部的測試函數(shù)test_2,test_1.
D:\pytest搜索測試用例規(guī)則>pytest --collect-only ============================= test session starts ============================= platform win32 -- Python 3.6.4, pytest-3.8.0, py-1.6.0, pluggy-0.7.1 rootdir: D:\pytest搜索測試用例規(guī)則, inifile: collected 4 items <Package 'D:\\pytest搜索測試用例規(guī)則\\測試用例目錄1'> <Module 'test_測試模塊1.py'> <Function 'test_2'> <Class 'TestClass_2'> <Instance '()'> <Function 'test_class_3'> <Module 'test_測試模塊2.py'> <Function 'test_1'> <Class 'TestClass_1'> <Instance '()'> <Function 'test_class_1'> ======================== no tests ran in 0.14 seconds =========================
我們大致已經能看出pytest的搜索規(guī)則,現(xiàn)在們再執(zhí)行一下所有用例看下 使用命令 pytest -v。可以看出確實只有4個用例被執(zhí)行了,也就是只識別到了4個用例,根據(jù)下面的輸出信息可以看出每個用例所在的位置
D:\pytest搜索測試用例規(guī)則>pytest -v ============================= test session starts ============================= platform win32 -- Python 3.6.4, pytest-3.8.0, py-1.6.0, pluggy-0.7.1 -- c:\python36\python.exe cachedir: .pytest_cache rootdir: D:\pytest搜索測試用例規(guī)則, inifile: collected 4 items 測試用例目錄1/test_測試模塊1.py::test_2 PASSED [ 25%] 測試用例目錄1/test_測試模塊1.py::TestClass_2::test_class_3 PASSED [ 50%] 測試用例目錄1/test_測試模塊2.py::test_1 PASSED [ 75%] 測試用例目錄1/test_測試模塊2.py::TestClass_1::test_class_1 PASSED [100%] ========================== 4 passed in 0.07 seconds ===========================
看完上述內容,你們對如何在python中配置pytest框架有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注創(chuàng)新互聯(lián)成都網(wǎng)站設計公司行業(yè)資訊頻道,感謝大家的支持。
另外有需要云服務器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
本文名稱:如何在python中配置pytest框架-創(chuàng)新互聯(lián)
當前URL:http://vcdvsql.cn/article36/djhssg.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)頁設計公司、小程序開發(fā)、建站公司、網(wǎng)站導航、品牌網(wǎng)站制作、自適應網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內容