pytest是一個非常成熟的全功能的python測試架構,主要有以下幾個特點:
簡單靈活,容易上手
支援參數化
能夠支援簡單的單元測試和複雜的功能測試,還可以用來做selenium/appnium等自動化測試、接口自動化測試(pytest+requests)
pytest具有很多第三方插件,并且可以自定義擴充,比較好用的如pytest-selenium(內建selenium)、pytest-html(完美html測試報告生成)、pytest-rerunfailures(失敗case重複執行)、pytest-xdist(多cpu分發)等
測試用例的skip和xfail處理
可以很好的和jenkins內建
report架構----allure 也支援了pytest
pip install -u pytest
測試類以test開頭,并且不能帶有init方法
以test_開頭的函數
以test開頭的類
所有的包pakege必須要有__init__.py檔案
斷言使用assert
pycharm裡代碼運作
-v 說明:可以輸出用例更加詳細的執行資訊,比如用例所在的檔案及用例名稱等
-s 說明:輸入我們用例中的調式資訊,比如print的列印資訊等
-x:遇到錯誤的用例,立即退出執行,并輸出結果
-v:表示檢視詳細的報告内容
-collect-only:表示把待執行的用例全部展示出來
-lf:隻執行上次失敗的用例
-vv :顯示詳細的測試結果
-tb=no:不展示用例失敗的錯誤詳情
-tb=line:展示用例失敗的代碼具體行數
-tb=short:展示更加詳細的錯誤資訊
-k "關鍵字" 說明:執行用例包含“關鍵字”的用例
-q 說明:簡化控制台的輸出,可以看出輸出資訊和上面的結果都不一樣, 下圖中有兩個..點代替了pass結果
-maxfail=num 當用例錯誤達到指定數量時,停止測試
m 說明:執行特定的測試用例。我們再次修改一下我們的用例,并添加一個新的用例
注意:-m後面不能帶''号(單引号),隻能帶“”(雙引号),不然識别不到
建立pytest.ini檔案(固定寫法)
跳過測試函數: 根據特定的條件,不執行辨別的測試函數