天天看點

###Pytest自動化測試架構學習筆記###01

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檔案(固定寫法)

跳過測試函數: 根據特定的條件,不執行辨別的測試函數