全功能Python測試框架:pytest

??python通用測試框架大多數人用的是unittest+HTMLTestRunner,這段時間看到了pytest文檔,發現這個框架和豐富的plugins很好用,所以來學習下pytest.

image.png

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

安裝pytest:

pip install -U pytest

驗證安裝的版本:

pytest --version

幾個pytest documentation中的例子:

例子1:

import pytest

# content of test_sample.py
def func(x):
    return x + 1
def test_answer():
    assert func(3) == 5

命令行切換到文件所在目錄,執行測試(也可以直接在IDE中運行):


image.png

這個測試返回一個失敗報告,因為func(3)不返回5。

例子2:
當需要編寫多個測試樣例的時候,我們可以將其放到一個測試類當中,如:

class TestClass:  
    def test_one(self):  
        x = "this"  
        assert 'h' in x  
  
    def test_two(self):  
        x = "hello"  
        assert hasattr(x, 'check') 

運行以上例子:


image.png

從測試結果中可以看到,該測試共執行了兩個測試樣例,一個失敗一個成功。同樣,我們也看到失敗樣例的詳細信息,和執行過程中的中間結果。-q即-quiet,作用是減少冗長,具體就是不再展示pytest的版本信息。

如何編寫pytest測試樣例

通過上面2個實例,我們發現編寫pytest測試樣例非常簡單,只需要按照下面的規則:

  • 測試文件以test_開頭(以_test結尾也可以)
  • 測試類以Test開頭,并且不能帶有 init 方法
  • 測試函數以test_開頭
  • 斷言使用基本的assert即可

運行模式

?? Pytest的多種運行模式,讓測試和調試變得更加得心應手,下面介紹5種常用的模式。在介紹之前需要提醒一句,運行pytest時會找當前目錄及其子目錄中的所有test_*.py 或 *_test.py格式的文件以及以test開頭的方法或者class,不然就會提示找不到可以運行的case了。

1.運行后生成測試報告(htmlReport)

安裝pytest-html:

pip install -U pytest-html

運行模式:

pytest --html=report.html

報告效果:


image.png

在以上報告中可以清晰的看到測試結果和錯誤原因,定位問題很容易。

2.運行指定的case

??當我們寫了較多的cases時,如果每次都要全部運行一遍,無疑是很浪費時間的,通過指定case來運行就很方便了。

例子代碼:

class TestClassOne(object):
    def test_one(self):
        x = "this"
        assert 't'in x

    def test_two(self):
        x = "hello"
        assert hasattr(x, 'check')


class TestClassTwo(object):
    def test_one(self):
        x = "iphone"
        assert 'p'in x

    def test_two(self):
        x = "apple"
        assert hasattr(x, 'check')

運行模式:

模式1:直接運行test_se.py文件中的所有cases:

pytest test_se.py

模式2:運行test_se.py文件中的TestClassOne這個class下的兩個cases:

pytest test_se.py::TestClassOne

模式3:運行test_se.py文件中的TestClassTwo這個class下的test_one:

pytest test_se.py::TestClassTwo::test_one

注意:定義class時,需要以T開頭,不然pytest是不會去運行該class的。

3.多進程運行cases

??當cases量很多時,運行時間也會變的很長,如果想縮短腳本運行的時長,就可以用多進程來運行。

安裝pytest-xdist:

pip install -U pytest-xdist

運行模式:

pytest test_se.py -n NUM

其中NUM填寫并發的進程數。

4.重試運行cases

??在做接口測試時,有事會遇到503或短時的網絡波動,導致case運行失敗,而這并非是我們期望的結果,此時可以就可以通過重試運行cases的方式來解決。

安裝pytest-rerunfailures:

pip install -U pytest-rerunfailures

運行模式:

pytest test_se.py --reruns NUM

NUM填寫重試的次數。

5.顯示print內容

??在運行測試腳本時,為了調試或打印一些內容,我們會在代碼中加一些print內容,但是在運行pytest時,這些內容不會顯示出來。如果帶上-s,就可以顯示了。

運行模式:

pytest test_se.py -s

??另外,pytest的多種運行模式是可以疊加執行的,比如說,你想同時運行4個進程,又想打印出print的內容。可以用:

pytest test_se.py -s -n 4

學習網站:
pytest documentation
好用的Pytest單元測試框架(《51測試天地》四十九(下)- 44)
Pytest學習筆記
pytest單元測試框架

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容