婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > python 如何用 Hypothesis 來自動化單元測試

python 如何用 Hypothesis 來自動化單元測試

熱門標簽:廈門crm外呼系統如何 長春人工智能電銷機器人官網 女王谷地圖標注 地圖標注推廣單頁 n400電話申請多少錢 百應ai電銷機器人鄭州 如何在地圖標注文字 ai地圖標注 西藏快速地圖標注地點

高質量的代碼離不開單元測試,而設計單元測試的用例往往又比較耗時,而且難以想到一些極端情況,本文講述如何使用 Hypothesis 來自動化單元測試

刷過力扣算法題的同學都知道,有時候覺得代碼已經很完善了,一提交才發現很多情況沒有考慮到。然后感嘆力扣的單元測試真的牛比。

因此,高質量的代碼離不開單元測試,如果現在還沒有寫過單元測試,建議先去學習以下常用的單元測試庫[1],只要實踐過,才能感受到本文開頭提到的那些痛點。

Hypothesis 是一個 Python 庫,用于讓單元測試編寫起來更簡單,運行時功能更強大,可以在代碼中查找您不會想到的極端情況。它穩定,強大且易于添加到任何現有測試框架中。它的工作原理是讓您編寫斷言每種情況都應該正確的測試,而不僅僅是您偶然想到的那些。

Hypothesis 的基礎知識

典型的單元測試需要自己寫一些測試用例,然后編寫測試函數,通過一段代碼運行它,然后根據預期結果檢查結果。

Hypothesis 有所不同。它是基于屬性進行單元測試。它通過生成與您的規范匹配的任意數據并檢查在這種情況下程序是否仍然有效。如果找到了一個失敗的用例,它將采用該示例并將其測試用例范圍縮減縮減為一定尺寸,然后對其進行簡化,直到找到一個仍會導致問題的小得多的示例。然后將其保存,后續單元測試時仍會使用這些用例。

現在就讓我們看看怎么用吧。

Hypothesis 快速入門

1、安裝

可以通過 pip 安裝,也可以通過源代碼安裝[2],也可以安裝一些擴展[3],如下:

pip install hypothesis
pip install hypothesis[pandas,django]

2、使用

先寫一段代碼,保存在 mycode.py 中,功能是對字符串進行特定的編碼和解碼,內容如下:

def encode(input_string):
 count = 1
 prev = ""
 lst = []
 for character in input_string:
  if character != prev:
   if prev:
    entry = (prev, count)
    lst.append(entry)
   count = 1
   prev = character
  else:
   count += 1
 entry = (character, count)
 lst.append(entry)
 return lst


def decode(lst):
 q = ""
 for character, count in lst:
  q += character * count
 return q

對這段代碼進行單元測試,往往需要寫很多測試用例,現在我們使用 hypothesis 來自動為我們測試,編寫 test_mycode.py (文件名隨意),內容如下:

from hypothesis import given
from mycode import decode,encode
from hypothesis.strategies import text
import unittest


class TestEncoding(unittest.TestCase):
 @given(text())
 def test_decode_inverts_encode(self, s):
  self.assertEqual(decode(encode(s)), s)


if __name__ == "__main__":
 unittest.main()

可以看出,這里并沒有出現具體的測試用例,而是使用來 text 的策略,相當于 hypothesis 自動窮舉來可能的情況,也可以看出它很容易可其他測試框架集成,這里是 unittest。現在來運行一下看看效果:

(py38env) ➜ tmp python test_mycode.py
Falsifying example: test_decode_inverts_encode(
 self=__main__.TestEncoding testMethod=test_decode_inverts_encode>, s='',
)
E
======================================================================
ERROR: test_decode_inverts_encode (__main__.TestEncoding)
----------------------------------------------------------------------
Traceback (most recent call last):
 File "test_mycode.py", line 9, in test_decode_inverts_encode
 def test_decode_inverts_encode(self, s):
 File "/Users/aaron/py38env/lib/python3.8/site-packages/hypothesis/core.py", line 1162, in wrapped_test
 raise the_error_hypothesis_found
 File "test_mycode.py", line 10, in test_decode_inverts_encode
 self.assertEqual(decode(encode(s)), s)
 File "/Users/aaron/tmp/mycode.py", line 14, in encode
 entry = (character, count)
UnboundLocalError: local variable 'character' referenced before assignment

----------------------------------------------------------------------
Ran 1 test in 0.048s

FAILED (errors=1)

這里測試出當字符串為 '' 的時候會拋出 UnboundLocalError 的異常。現在我們來修復這個 bug,然后把所有的測試用例 s 給打印出來,看看它用了哪些測試用例。

encode 函數加入以下代碼:

if not input_string:
 return []

test_mycode.py 文件打印出測試用例:

@given(text())
def test_decode_inverts_encode(self, s):
 print(f"{s=}")
 self.assertEqual(decode(encode(s)), s)

再次執行:

(py38env) ➜ tmp python test_mycode.py
s=''
s='1'
s='0'
s='0'
s='0'
s='Ā'
s='\U000cf5e5'
s='0'
s=''
s='0'
s='0'
s='E'
s=")dù'\x18\U0003deb3¤jd"
s='\U0005bc37\x07\U000537a1ÝÀãiÎ\U000ce9e5\x0b'
s='\U0005bc37\U0005bc37\U000537a1ÝÀãiÎ\U000ce9e5\x0b'
s='\U0005bc37\U000537a1\U000537a1ÝÀãiÎ\U000ce9e5\x0b'
s='À\U000537a1\U000537a1ÝÀãiÎ\U000ce9e5\x0b'
s='\U000965e1\x12\x85\U000f500aÄÃc'
s='\n\U0004466c\x86Î\x07'
s='Ê\U00063f1e\x01G\x88'
s='ÚV\n'
s='VV\n'
s='\U0008debf湆è'
s='\U0008debf湆è'
s='\U0008debf湆'
s='\U0008debf\U0008debf'
s='\U0008debf\U0008debfó]½àq\x82#\U00015196\U0001c8beg'
s='\U0008debfgó]½àq\x82#\U00015196\U0001c8beg'
s='?'
s='Î'
s='Î\U00085b9e'
s="Î8'?\U00057c38Ù;\x07\U000a5ea8Ò»=\U00091d5b~8뺈"
s='\U000d6497Ý>'
s='\U000e0f01'
s='\U000e0f01Å0y¢KN®'
s='\U000e0f01Å0y¢KN®'
s='\U00050a06'
s='Å\U000b98b3か\U000ba80aá`Ã-Êu\x8c\x90³FÔ"'
s='\x8e\U0004612a\x83ç'
s='\x8e'
s='\x8e\x98\U000fb3e0\U0010d2b3\x10\x82\x94Ð渥'
s='¥W'
s='p\U000e5a2aE·`ì'
s='\U000b80f8\x12\U000c2d54'
s='.\U000703de'
s='6\U00010ffa\U000f7994\x8e'
s='116\U000f7994\x8e'
s='1?6\U000f7994\x8e'
s='4?6\U000f7994\x8e'
s='4\x8e6\U000f7994\x8e'
s='0'
s='\U0006a564´Ð\x93ü\x9ebi\x1cÑ'
s='\U000ceb6f'
s='\U000ceb6f\xa0\x08'
s='\U000ceb6f\xa0\x08'
s='\U000ceb6fꄃ\x08'
s='\U000ceb6fꄃ勻\U0007cc15\U000b2aaa×**'
s='\U000ceb6fꄃ勻'
s='勻ꄃ勻'
s='J\x14?ö'
s='q)'
s='q)'
s='q\U00060931'
s='q6'
s='\U000e3441'
s='\U000e3441\U00019958¯'
s='\x13'
s='\U000f34dbk'
s='KptÛà'
s='\nö\x93'
s='\n\n\x93'
s='\U00019c8dѳ\U00056cbd\U000e3b2f\U00058d302'
s='\x90=R\x8bß\x03'
s='\x9a'
s='\U000147e7'
s='\U000147e7\x85\U0007a3ef'
s='\U000147e7\U00050a070Â>'
s='\U000a4089\x0eC+RÁ\x02\x97\x9cüÌïSS\U0006cbc5;ÿ~\x16\x019VÇ\U000a32fdQ÷\x15'
s='ÞÚ¾\x19©Z®'
s='ਸ਼æ'
s='\U000cd45a'
s='\U000cd45a\U000e15cbÑ\x08J\ueb3eúß\x07I\x91\x9a\x18\x16Ç\x80\x1a'
s='\x8f}º\x0eq\x0b'
s='\x0e}º\x0eq\x0b'
s="\U000e05a3¶º[fõ\x8bÜR'ͼt\x97íW\x05\U000caea9\U0008fd74\U000e8f1c¹?dfƾ\x13"
s='\x10\U000e12e2ù\U0006f96erý\U00014baf\x00\x95\U000dbc92É\U00081613µ\U0003b865Z\U0008cc3c'
s='ú\U000b561f\x8fÎ'
s='\tàÖ÷'
s='à\x92©Ì\U000618fa\x92'
s='\U000aaf94\x94\x84\U000cda69\U0005291a\U000a63deþ¿O\x8a>\U000b458bÊ.\U00086f07\x1a'
s='\U0009754e?U_\xa0\x13PQ\x18º\x07\U0006c9c5.Á'
s='\U00102456'
s='³WᵎÕ'
s='\x14\x1c'
s='\x14'
s='\x14\U00105bcd"\x10Ô\x99\U000a5032R\U00056c44V÷>+\U000aaff2ñ®\U000d7570%ª!\U00032553´8x^«'
s='\x00\U000e2ac4¼ÄUrB'
s='\x00\U000e2ac4¼ÄUrB'
s='\x00\U000e2ac4¼ÄUrB'
s='ª\x1aU\x8aÇ\U000b2fb9\U0005a586'
.
----------------------------------------------------------------------
Ran 1 test in 0.180s

OK

從執行結果可以看出,'' 首先被測試,其次 hypothesis 使用了大量的極端測試用例,減輕了手寫的負擔,大大提升了效率。

雖然 hypothesis 具有自動記憶功能,你仍然可以顯式的指定某個測試用例一直被測試,而且這是推薦的做法,比如我想在每次的測試中都測試 '',可以這樣寫:

from hypothesis import given, example
from hypothesis.strategies import text


@given(text())
@example("")
def test_decode_inverts_encode(s):
 assert decode(encode(s)) == s

這一點非常有用,提升了測試代碼的可讀性,可以用來告訴開發人員或者未來的自己,輸入的字符串必須要考慮 '' 的情形。

此外,執行單元測試,不一定要使用 unittest.main(),也可以這樣,是不是很方便:

if __name__ == "__main__":
 test_decode_inverts_encode()

3、其他策略參考

從哪里開始

以上僅僅是拋磚引玉,hypothesis 還有很多自動化的特性,不再一一列舉,最好的學習方法是邊做,邊嘗試。hypothesis 是一個開源項目,有著詳細的官方文檔[4],GitHub 倉庫[5]這里都是你開啟自動化測試的好地方:

參考資料

[1]

庫: https://realpython.com/python-testing/

[2]

源代碼安裝: https://github.com/HypothesisWorks/hypothesis/blob/master/CONTRIBUTING.rst

[3]

擴展: https://hypothesis.readthedocs.io/en/latest/extras.html

[4]

官方文檔: https://hypothesis.readthedocs.io/en/latest/quickstart.html#running-tests

[5]

GitHub 倉庫: https://github.com/HypothesisWorks/hypothesis/

以上就是python 如何用 Hypothesis 來自動化單元測試的詳細內容,更多關于python 用 Hypothesis 來自動化單元測試的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • python自動提取文本中的時間(包含中文日期)
  • 十個Python自動化常用操作,即拿即用
  • 如何用 Python 子進程關閉 Excel 自動化中的彈窗
  • 教你怎么用Python處理excel實現自動化辦公
  • Python 制作自動化翻譯工具
  • python實現百度文庫自動化爬取
  • 使用Python自動化Microsoft Excel和Word的操作方法
  • python使用pytest接口自動化測試的使用
  • python+requests+pytest接口自動化的實現示例
  • python+pywinauto+lackey實現PC端exe自動化的示例代碼
  • python自動化調用百度api解決驗證碼
  • python 自動化偷懶的四個實用操作
  • python實現自動化群控的步驟
  • python之Django自動化資產掃描的實現
  • Python 實現自動化Excel報表的步驟
  • python自動化實現自動回復QQ消息
  • 教你用Python實現自動提取并收集信息的功能

標簽:廊坊 拉薩 興安盟 亳州 渭南 內江 綿陽 黔東

巨人網絡通訊聲明:本文標題《python 如何用 Hypothesis 來自動化單元測試》,本文關鍵詞  python,如,何用,Hypothesis,來,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《python 如何用 Hypothesis 來自動化單元測試》相關的同類信息!
  • 本頁收集關于python 如何用 Hypothesis 來自動化單元測試的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    91在线视频免费观看| 日韩免费福利电影在线观看| 国产一本一道久久香蕉| 亚洲精品国产无天堂网2021| 欧美丰满一区二区免费视频 | 欧美精品久久一区二区三区| 亚洲色图制服诱惑 | 欧美专区日韩专区| 国产成人免费高清| 亚洲欧美影音先锋| 久久精品免费看| 国产伦精一区二区三区| av成人免费在线观看| 色综合久久久久综合体桃花网| 色久综合一二码| 欧美va在线播放| 成人精品视频.| 91免费精品国自产拍在线不卡| 欧美三电影在线| 亚洲国产裸拍裸体视频在线观看乱了| 56国语精品自产拍在线观看| 亚洲人123区| 国精产品一区一区三区mba视频| 国产精品日日摸夜夜摸av| 亚洲欧美日韩精品久久久久| 日韩黄色在线观看| 日本电影欧美片| 久88久久88久久久| 国产欧美一区二区精品秋霞影院 | 精品视频1区2区| 91成人看片片| 91玉足脚交白嫩脚丫在线播放| 日本韩国欧美一区二区三区| 国产精品国产三级国产普通话三级 | 亚洲一区二区高清| 色哟哟日韩精品| 亚洲激情图片qvod| 在线观看日韩av先锋影音电影院| 国产精品资源在线看| 亚洲欧美偷拍另类a∨色屁股| 喷白浆一区二区| 91精品久久久久久久99蜜桃| 日韩精品一二三四| 日韩伦理免费电影| 国产一区91精品张津瑜| 中文字幕亚洲电影| 91麻豆swag| 午夜激情综合网| 美女www一区二区| 欧美三级一区二区| 亚洲成人精品一区二区| 亚洲欧美另类久久久精品2019| 91啪亚洲精品| 视频在线观看一区二区三区| 精品粉嫩超白一线天av| 成人一区二区三区视频| 欧美综合色免费| 99re热这里只有精品免费视频| 亚洲国产成人av好男人在线观看| 91精品国产综合久久福利软件| 国产美女精品一区二区三区| 亚洲人妖av一区二区| 欧美一区二区人人喊爽| 在线视频欧美区| 盗摄精品av一区二区三区| 首页亚洲欧美制服丝腿| 亚洲欧洲精品一区二区精品久久久 | 欧美在线你懂的| 99热99精品| 成人自拍视频在线观看| 视频一区免费在线观看| 亚洲成人av电影在线| 亚洲午夜视频在线观看| 午夜欧美2019年伦理| 亚洲国产精品久久久久秋霞影院 | 国产精品久久久久久久久免费樱桃| 日韩视频中午一区| 2023国产精品视频| 中文字幕久久午夜不卡| 国产欧美日韩激情| 亚洲美女一区二区三区| 亚洲妇熟xx妇色黄| 日本特黄久久久高潮| 美女视频第一区二区三区免费观看网站| 亚洲第一成年网| 紧缚奴在线一区二区三区| 国产精品一区二区男女羞羞无遮挡| 肉肉av福利一精品导航| 国产激情视频一区二区在线观看 | 欧美剧情片在线观看| 日韩一区二区电影| 有码一区二区三区| 国产一区二区三区综合| 国产ts人妖一区二区| 色婷婷久久久久swag精品 | 亚洲欧美aⅴ...| 国产日韩视频一区二区三区| 国产精品福利一区| 亚洲成人av一区二区| 粉嫩av一区二区三区在线播放 | 国产精品免费丝袜| 日韩电影在线观看网站| 欧美亚洲愉拍一区二区| 久久综合九色综合久久久精品综合| 国产精品久久久爽爽爽麻豆色哟哟| 一区二区三区在线播放| 国产精品 欧美精品| 精品国产伦一区二区三区观看方式 | 一区二区三区精品| 丁香五精品蜜臀久久久久99网站| 在线视频国内一区二区| 欧美激情在线观看视频免费| 亚洲图片有声小说| 在线一区二区视频| 国产精品成人一区二区艾草| 国产呦精品一区二区三区网站| 日韩你懂的在线观看| 亚洲制服欧美中文字幕中文字幕| 国产乱码字幕精品高清av| 欧美一区二区日韩| 国产午夜久久久久| 国产成人av一区二区三区在线 | 白白色 亚洲乱淫| 国产日韩欧美精品在线| 高清在线不卡av| 亚洲精品中文在线观看| 91精品久久久久久久91蜜桃| 国产一区不卡在线| 国产精品私人自拍| 国产精品久线观看视频| 91一区在线观看| 亚洲精品久久久久久国产精华液| 91免费在线看| 日韩精品一卡二卡三卡四卡无卡| 在线播放中文一区| aaa国产一区| 日韩在线a电影| 久久久国产精品午夜一区ai换脸| 成人av片在线观看| 一区二区久久久久久| 欧美男男青年gay1069videost | 欧美国产在线观看| 欧美日韩精品是欧美日韩精品| 午夜精品爽啪视频| 一区二区三区四区乱视频| 日韩午夜小视频| 欧美系列在线观看| 日本高清成人免费播放| 欧美一区二区日韩| 欧美久久免费观看| 欧美电影影音先锋| 精品少妇一区二区三区| 欧美日韩国产在线观看| jlzzjlzz亚洲日本少妇| 91美女蜜桃在线| 欧美网站一区二区| 这里只有精品免费| 91精品国产91久久久久久最新毛片 | 波多野结衣在线aⅴ中文字幕不卡| 麻豆精品精品国产自在97香蕉| 亚洲线精品一区二区三区| 一区二区三区欧美亚洲| 亚洲人成网站色在线观看| 亚洲午夜精品网| 麻豆免费精品视频| 激情亚洲综合在线| 国产精品99久| 成人免费视频视频| 成人免费毛片高清视频| 欧美日韩中文精品| 久久欧美中文字幕| 一二三区精品福利视频| 久久久精品2019中文字幕之3| 一区二区三区成人| 午夜精品久久久久久久久| 国产白丝网站精品污在线入口| 成人sese在线| 久久久久久日产精品| 国产日产欧美精品一区二区三区| 久久这里只有精品6| 国产日韩一级二级三级| 看国产成人h片视频| 欧美吻胸吃奶大尺度电影| 欧美tk丨vk视频| 久久综合久久鬼色中文字| 美女视频网站黄色亚洲| 国产三级精品视频| 国产精品 欧美精品| 久久色在线视频| 国产成人免费网站| 久久久久国产精品人| 成人h精品动漫一区二区三区| 久久久蜜臀国产一区二区| 99在线视频精品| 亚洲一二三四区| 国产偷v国产偷v亚洲高清| 日本韩国欧美在线| 韩国成人福利片在线播放| 亚洲精品一区二区三区在线观看| 成人精品免费看|