校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > pytest之assert斷言的具體使用

pytest之assert斷言的具體使用

熱門標簽:房產電銷外呼系統 地圖制圖標注位置改變是移位嗎 315電話機器人廣告 浙江電銷卡外呼系統好用嗎 蓋州市地圖標注 地圖標注微信發送位置不顯示 南京銷售外呼系統軟件 上海機器人外呼系統哪家好 地圖標注的意義點

背景

本文總結使用pytest編寫自動化測試時常用的assert斷言。

說明

本文將從以下幾點做總結:

  1. 為測試結果作斷言
  2. 為斷言不通過的結果添加說明信息
  3. 為預期異常作斷言
  4. 為失敗斷言自定義說明信息

為測試結果作斷言

在斷言方面,pytest框架比其他類似的框架(比如unittest)更加簡潔,易用,我想這是我選擇pytest作為自動化測試框架之一的原因之一。
pytest的assert斷言關鍵字支持使用python內置的assert表達式。可以理解為pytest的斷言就是直接使用python自帶的assert關鍵字。

python assert的概念:

Python assert(斷言)用于判斷一個表達式,在表達式條件為 false 的時候觸發異常。

我們可以在在assert后面添加任何符合python標準的表達式,如果表達式的值通過bool轉換后等于False,則意味著斷言結果為失敗。

以下舉例常用的表達式:

# ./test_case/test_func.py
import pytest
from func import *

class TestFunc:
 
 def test_add_by_class(self):
  assert add(2,3) == 5

def test_add_by_func_aaa():

 assert 'a' in 'abc'
 assert 'a' not in 'bbc'
 something = True
 assert something
 something = False
 assert not something
 assert 1==1
 assert 1!=2
 assert 'a' is 'a'
 assert 'a' is not 'b'
 assert 1  2
 assert 2 > 1
 assert 1 = 1
 assert 1 >= 1
 assert add(3,3) == 6

'''
# 以上全是合法的表達式且表達式的值都為True,所以測試結果為通過
============================= test session starts =============================
platform win32 -- Python 3.7.0, pytest-5.3.4, py-1.8.1, pluggy-0.13.1 -- D:\Python3.7\python.exe
cachedir: .pytest_cache
rootdir: D:\Python3.7\project\pytest, inifile: pytest.ini
plugins: allure-pytest-2.8.9, rerunfailures-8.0
collecting ... collected 2 items

test_case/test_func.py::TestFunc::test_add_by_class PASSED               [ 50%]
test_case/test_func.py::test_add_by_func_aaa PASSED                      [100%]

============================== 2 passed in 0.06s ==============================
[Finished in 1.8s]

'''

為斷言不通過的結果添加說明信息

在編寫測試時,為了提高易用性,我們想知道斷言失敗時的一些關于失敗的原因等說明信息,assert也能滿足該功能。
請看示例:

# ./test_case/test_func.py
import pytest
from func import *

class TestFunc:
 def test_add_by_class(self):
  assert add(2,3) == 5


def test_add_by_func_aaa():
 assert add(3,3) == 5, "3+3應該等于6"

'''
============================= test session starts =============================
platform win32 -- Python 3.7.0, pytest-5.3.4, py-1.8.1, pluggy-0.13.1 -- D:\Python3.7\python.exe
cachedir: .pytest_cache
rootdir: D:\Python3.7\project\pytest, inifile: pytest.ini
plugins: allure-pytest-2.8.9, rerunfailures-8.0
collecting ... collected 2 items

test_case/test_func.py::TestFunc::test_add_by_class PASSED               [ 50%]
test_case/test_func.py::test_add_by_func_aaa FAILED                      [100%]

================================== FAILURES ===================================
____________________________ test_add_by_func_aaa _____________________________

    def test_add_by_func_aaa():
    
>    assert add(3,3) == 5, "3+3應該等于6"
E    AssertionError: 3+3應該等于6
E    assert 6 == 5
E      -6
E      +5

test_case\test_func.py:14: AssertionError
========================= 1 failed, 1 passed in 0.09s =========================
[Finished in 1.4s]
'''

為預期異常作斷言

在某些測試用例中,比如異常測試用例,測試的結果必然是失敗并應該爆出異常的。這時候自動化測試用例的期望結果就是該異常。如果期望結果等于該異常,那么測試用例執行通過,否則用例結果為失敗。pytest提供為為預期異常作斷言的方法:pytest.raises()。一般結合with上下文管理器使用。

使用示例:

# ./func.py
def add(a,b):
 if isinstance(a,int) and isinstance(b,int):
  return a+b
 else:
  raise NameError('數據類型錯誤')


# ./test_case/test_func.py
import pytest
from func import *

class TestFunc:

 # 正常測試用例
 def test_add_by_class(self):
  assert add(2,3) == 5

# 異常測試用例,期望結果為爆出TypeError異常
def test_add_by_func_aaa():
 with pytest.raises(TypeError):
  add('3',4)
  

# ./run_test.py
import pytest

if __name__ == '__main__':
 pytest.main(['-v'])

'''
============================= test session starts =============================
platform win32 -- Python 3.7.0, pytest-5.3.4, py-1.8.1, pluggy-0.13.1 -- D:\Python3.7\python.exe
cachedir: .pytest_cache
rootdir: D:\Python3.7\project\pytest, inifile: pytest.ini
plugins: allure-pytest-2.8.9, rerunfailures-8.0
collecting ... collected 2 items

test_case/test_func.py::TestFunc::test_add_by_class PASSED               [ 50%]
test_case/test_func.py::test_add_by_func_aaa PASSED                      [100%]

============================== 2 passed in 0.06s ==============================
[Finished in 1.4s]
''' 

接下來看看沒有爆出預期異常的示例:

# ./func.py
def add(a,b):
 # 指定異常
 raise NameError("天降異常")
 if isinstance(a,int) and isinstance(b,int):
  return a+b
 else:
  raise NameError('數據類型錯誤')

# ./test_case/test_func.py
import pytest
from func import *
'''
class TestFunc:

 # 正常測試用例
 def test_add_by_class(self):
  assert add(2,3) == 5
'''
# 異常測試用例,期望結果為爆出TypeError異常
def test_add_by_func_aaa():
 with pytest.raises(TypeError):
  add('3',4)
  
# ./run_test.py
import pytest

if __name__ == '__main__':
 pytest.main(['-v'])


'''
============================= test session starts =============================
platform win32 -- Python 3.7.0, pytest-5.3.4, py-1.8.1, pluggy-0.13.1 -- D:\Python3.7\python.exe
cachedir: .pytest_cache
rootdir: D:\Python3.7\project\pytest, inifile: pytest.ini
plugins: allure-pytest-2.8.9, rerunfailures-8.0
collecting ... collected 1 item

test_case/test_func.py::test_add_by_func_aaa FAILED                      [100%]

================================== FAILURES ===================================
____________________________ test_add_by_func_aaa _____________________________

    def test_add_by_func_aaa():
     with pytest.raises(TypeError):
>     add('3',4)

test_case\test_func.py:14: 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _

a = '3', b = 4

    def add(a,b):
     # 指定異常
>    raise NameError("天降異常")
E    NameError: 天降異常

func.py:4: NameError
============================== 1 failed in 0.09s ==============================
[Finished in 1.4s]
'''

判定用例執行結果為失敗。

上面我們只是斷言了異常的類型。但有的時候我們想更進一步斷言異常的說明信息,pytest也可以做到。with pytest.raises()執行結束后會生成一個ExceptionInfo的實例對象。該對象包含type , value, traceback屬性。value屬性就是我們需要的異常說明信息。

見示例:

# ./func.py
def add(a,b):
 if isinstance(a,int) and isinstance(b,int):
  return a+b
 else:
  raise TypeError('數據類型錯誤')
 
# ./test_case/test_func.py
import pytest
from func import *

class TestFunc:

 # 正常測試用例
 def test_add_by_class(self):
  assert add(2,3) == 5

# 異常測試用例,期望結果為爆出TypeError異常
def test_add_by_func_aaa():
 with pytest.raises(TypeError) as E:
  add('3',4)
 print(E.type)
 print(E.value)
 print(E.traceback)
 # 加入該不通過斷言為了查看stdout
 assert 1 == 2


# ./run_test.py
import pytest

if __name__ == '__main__':
 pytest.main(['-v'])

'''
============================= test session starts =============================
platform win32 -- Python 3.7.0, pytest-5.3.4, py-1.8.1, pluggy-0.13.1 -- D:\Python3.7\python.exe
cachedir: .pytest_cache
rootdir: D:\Python3.7\project\pytest, inifile: pytest.ini
plugins: allure-pytest-2.8.9, rerunfailures-8.0
collecting ... collected 2 items

test_case/test_func.py::TestFunc::test_add_by_class PASSED               [ 50%]
test_case/test_func.py::test_add_by_func_aaa FAILED                      [100%]

================================== FAILURES ===================================
____________________________ test_add_by_func_aaa _____________________________

    def test_add_by_func_aaa():
     with pytest.raises(TypeError) as E:
      add('3',4)
     print(E.type)
     print(E.value)
     print(E.traceback)
>    assert 1 == 2
E    assert 1 == 2
E      -1
E      +2

test_case\test_func.py:18: AssertionError
---------------------------- Captured stdout call -----------------------------
class 'TypeError'>
數據類型錯誤
[TracebackEntry D:\Python3.7\project\pytest\test_case\test_func.py:14>, TracebackEntry D:\Python3.7\project\pytest\func.py:6>]
========================= 1 failed, 1 passed in 0.10s =========================
[Finished in 1.4s]
'''

控制臺輸出的“Captured stdout call”就是異常的信息,包含類型,異常說明,異常跟蹤信息。
可以通過assert斷言這些信息。

也可以通過給pytest.raises()傳入match關鍵字參數來完成E.value的斷言,這里運用到的是python中正則表達式的原理。

示例:

該示例意味斷言通過

def test_add_by_func_aaa():
 with pytest.raises(TypeError, match=r'.*類型錯誤$') as E:
  add('3',4)

該示例意味斷言失敗:

# 異常測試用例,期望結果為爆出TypeError異常
def test_add_by_func_aaa():
 with pytest.raises(TypeError, match=r'.*正確$') as E:
  add('3',4)
'''
During handling of the above exception, another exception occurred:

    def test_add_by_func_aaa():
     with pytest.raises(TypeError, match=r'.*正確$') as E:
>     add('3',4)
E     AssertionError: Pattern '.*正確$' not found in '數據類型錯誤'

test_case\test_func.py:14: AssertionError
'''

如果,某個測試用例可能出現不同的預期異常,只要爆出的異常在預期的幾個異常之內,那么如何斷言呢。解決方法很簡單,原理和接口都沒變,只是在pytest.raises()中傳入異常類型的參數,從傳入一個異常類型,改變為傳入一個異常類型組成的元組。同樣只是傳入一個參數。

示例:

# ./func.py
def add(a,b):
 raise NameError('名字錯了')
 if isinstance(a,int) and isinstance(b,int):
  return a+b
 else:
  raise TypeError('數據類型錯誤')
 
# ./test_case/test_func.py
import pytest
from func import *

'''
class TestFunc:

 # 正常測試用例
 def test_add_by_class(self):
  assert add(2,3) == 5
'''

# 異常測試用例,期望結果為爆出TypeError異常
def test_add_by_func_aaa():
 with pytest.raises((TypeError,NameError),match=r'.*錯.*$') as E:
  add('3',4)
 
 
# ./run_test.py
import pytest

if __name__ == '__main__':
 pytest.main(['-v'])
 
'''
============================= test session starts =============================
platform win32 -- Python 3.7.0, pytest-5.3.4, py-1.8.1, pluggy-0.13.1 -- D:\Python3.7\python.exe
cachedir: .pytest_cache
rootdir: D:\Python3.7\project\pytest, inifile: pytest.ini
plugins: allure-pytest-2.8.9, rerunfailures-8.0
collecting ... collected 1 item

test_case/test_func.py::test_add_by_func_aaa PASSED                      [100%]

============================== 1 passed in 0.04s ==============================
[Finished in 1.4s]
'''

為失敗斷言自定義說明信息

這種行為,相當于改變了pytest的運行方式,雖然只是一種錦上添花的改變。我們通過編寫hook函數來改變pytest的行為。hook函數是pytest提供的,有很多,各個hook函數的詳細定義應該參考pytest的官方文檔。
為失敗斷言自定義說明信息是通過pytest_assertrepr_compare這個hook函數完成的。
先看沒有編寫pytest_assertrepr_compare這個hook函數時,默認的失敗斷言說明:

def test_add_by_func_aaa():
 assert 'aaa' == 'bbb'

'''
================================== FAILURES ===================================
____________________________ test_add_by_func_aaa _____________________________

    def test_add_by_func_aaa():
>    assert 'aaa' == 'bbb'
E    AssertionError: assert 'aaa' == 'bbb'
E      - aaa
E      + bbb

test_case\test_func.py:16: AssertionError
'''

再看編寫pytest_assertrepr_compare這個hook函數后:

# ./conftest.py

def pytest_assertrepr_compare(op, left, right):
    if isinstance(left, str) and isinstance(right, str) and op == "==":
        return ['兩個字符串比較:',
                '   值: %s != %s' % (left, right)]


# ./test_case/test_func.py
import pytest
def test_add_by_func_aaa():
 assert 'aaa' == 'bbb'


'''
.F                                                                       [100%]
================================== FAILURES ===================================
____________________________ test_add_by_func_aaa _____________________________

    def test_add_by_func_aaa():
>    assert 'aaa' == 'bbb'
E    assert 兩個字符串比較:
E         值: aaa != bbb

test_case\test_func.py:15: AssertionError
1 failed, 1 passed in 0.09s
[Finished in 1.5s]
'''

pytest還提供其他的hook函數,這些函數的作用就是用來改變pytest的運行方式和運行效果。所以編寫第三方插件一般是使用這些hook函數。

到此這篇關于pytest之assert斷言的具體使用的文章就介紹到這了,更多相關pytest assert斷言內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 簡單了解Java斷言利器AssertJ原理及用法
  • Node.js API詳解之 assert模塊用法實例分析
  • python 錯誤處理 assert詳解
  • Python3 assert斷言實現原理解析
  • 解決pytorch報錯:AssertionError: Invalid device id的問題
  • Python assert關鍵字原理及實例解析
  • python3 assert 斷言的使用詳解 (區別于python2)
  • Java Assert.assertEquals案例詳解

標簽:雙鴨山 臨汾 陽泉 日照 金華 貴州 赤峰 克拉瑪依

巨人網絡通訊聲明:本文標題《pytest之assert斷言的具體使用》,本文關鍵詞  pytest,之,assert,斷言,的,具體,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《pytest之assert斷言的具體使用》相關的同類信息!
  • 本頁收集關于pytest之assert斷言的具體使用的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    678五月天丁香亚洲综合网| 色哟哟国产精品| 色94色欧美sute亚洲13| 欧美一区二区三区婷婷月色| 日韩理论片中文av| 日本美女一区二区三区| 91色porny| 国产精品白丝在线| 国产一区二区三区四区在线观看| 色狠狠av一区二区三区| 日本一区二区视频在线| 久久国产精品无码网站| 欧美三级午夜理伦三级中视频| 日本一区二区视频在线观看| 国产综合久久久久久鬼色| 7777精品伊人久久久大香线蕉的 | 91在线视频18| 欧美岛国在线观看| 午夜精品久久久久久久蜜桃app| 国产一区二区三区精品欧美日韩一区二区三区| 欧美视频完全免费看| 国产亚洲综合在线| 中文字幕中文字幕一区| 国产xxx精品视频大全| 欧美一区二区女人| 日韩—二三区免费观看av| 不卡的av在线| 国产精品理伦片| 激情国产一区二区| 欧美亚洲一区二区在线| 国产视频一区不卡| 婷婷综合另类小说色区| 欧美肥妇bbw| 亚洲午夜免费视频| 欧美久久高跟鞋激| 伊人开心综合网| 欧美亚洲综合一区| 亚洲永久免费视频| 欧美性色aⅴ视频一区日韩精品| 国产精品免费久久| 国产精品538一区二区在线| 国产午夜精品在线观看| 国产专区欧美精品| 中文字幕成人av| 国产一区二区三区香蕉| 亚洲国产岛国毛片在线| 麻豆成人在线观看| 北条麻妃国产九九精品视频| 国产精品福利一区二区三区| 国产成a人亚洲| 中文字幕一区二区三区不卡 | 欧美性猛交xxxxxx富婆| 婷婷综合五月天| 在线播放91灌醉迷j高跟美女| 欧美96一区二区免费视频| 欧美色精品在线视频| 免费观看在线色综合| 4438亚洲最大| 欧美日精品一区视频| 欧美一级高清片| 青青草91视频| 国产婷婷色一区二区三区四区| 国产91高潮流白浆在线麻豆| 综合激情网...| 欧美另类高清zo欧美| 国产一区二区三区四区在线观看| 国产欧美一区在线| 97se亚洲国产综合自在线| 亚洲3atv精品一区二区三区| 91精品国产欧美一区二区| 国产精品亚洲人在线观看| 久久久久久久久99精品| 欧洲精品在线观看| 免费在线观看成人| 亚洲丝袜自拍清纯另类| 91 com成人网| 夜夜嗨av一区二区三区四季av| 欧美一级片免费看| 成人app网站| 日韩精品色哟哟| 中文字幕欧美国产| 日韩视频免费观看高清在线视频| 久久精品国产亚洲一区二区三区| 综合电影一区二区三区 | 国产精品成人免费| 2023国产精品| 在线看国产日韩| 国产一区二区视频在线| 一区二区三区中文字幕精品精品 | 欧洲av在线精品| 国产成人精品免费| 日本在线不卡视频| 欧美一级黄色大片| 9191久久久久久久久久久| 成人免费毛片高清视频| 国产综合久久久久影院| 午夜影院久久久| 亚洲综合另类小说| 国产日韩欧美制服另类| www日韩大片| 欧美精品一卡两卡| 欧美三片在线视频观看| 国产成人免费视频精品含羞草妖精| 性欧美疯狂xxxxbbbb| 国产精品人成在线观看免费| 精品福利视频一区二区三区| 欧美日韩国产经典色站一区二区三区| 精一区二区三区| 日精品一区二区三区| 亚洲国产电影在线观看| 国产精品麻豆99久久久久久| 666欧美在线视频| 91精品国产综合久久久久久| 色综合久久久久久久久久久| eeuss鲁片一区二区三区| 久久99精品久久久| 老司机精品视频导航| 五月天视频一区| 蜜臀av一区二区在线免费观看 | 91碰在线视频| 成人激情免费网站| 97精品久久久久中文字幕| 成人免费观看av| 免费视频最近日韩| 日韩成人dvd| 一区二区三区四区在线播放| 亚洲一区二区三区四区在线 | 奇米精品一区二区三区四区 | 日韩毛片视频在线看| 亚洲人成小说网站色在线| 国产精品另类一区| 一区二区三区国产精品| 亚洲影视在线播放| 日本中文一区二区三区| 久久99精品国产.久久久久| 久久99精品国产麻豆不卡| 国产一区二三区好的| 首页国产欧美久久| 国产福利视频一区二区三区| 蜜桃av一区二区三区电影| 国产剧情在线观看一区二区| 国内精品伊人久久久久av一坑| 成人激情小说乱人伦| 99久久99久久久精品齐齐| 69成人精品免费视频| 日韩免费在线观看| 亚洲图片激情小说| 亚洲综合一二三区| 另类小说一区二区三区| 国产美女在线观看一区| 色综合天天综合色综合av | 亚洲人成影院在线观看| 五月激情综合色| 久久av中文字幕片| 色噜噜狠狠成人中文综合| 欧美日韩在线不卡| 日本一区二区免费在线观看视频| 中文字幕在线不卡| 久久精品国产久精国产爱| 国产三级三级三级精品8ⅰ区| 国产精品资源站在线| 日本高清免费不卡视频| 51精品国自产在线| 久久尤物电影视频在线观看| 亚洲欧美视频在线观看视频| 天天色图综合网| 91亚洲精品久久久蜜桃网站| 欧美精品vⅰdeose4hd| 国产欧美精品一区二区色综合| 一区二区三区日韩欧美| 日本欧美肥老太交大片| 色综合天天综合色综合av | 蜜桃视频第一区免费观看| 国产美女视频一区| 欧美精品在线观看一区二区| 国产精品系列在线| 国产一区二区三区视频在线播放| 国产成人丝袜美腿| www国产成人免费观看视频 深夜成人网| 国产午夜三级一区二区三| 精品影视av免费| 91啪亚洲精品| 中文字幕亚洲在| 久久99精品国产.久久久久| 日韩一卡二卡三卡四卡| 精品国产一区二区三区四区四| 午夜久久久久久久久| 国产成人免费av在线| 久久免费看少妇高潮| 亚洲自拍偷拍网站| 91久久国产最好的精华液| 精品1区2区在线观看| 久99久精品视频免费观看| 91麻豆蜜桃一区二区三区| 亚洲三级小视频| av不卡一区二区三区| 国产三级一区二区三区| 国产99一区视频免费| 久久久精品中文字幕麻豆发布| 激情五月激情综合网|