日韩黑丝制服一区视频播放|日韩欧美人妻丝袜视频在线观看|九九影院一级蜜桃|亚洲中文在线导航|青草草视频在线观看|婷婷五月色伊人网站|日本一区二区在线|国产AV一二三四区毛片|正在播放久草视频|亚洲色图精品一区

分享

pytest文檔19-doctest測試框架

 上海悠悠 2021-05-27

前言

doctest從字面意思上看,那就是文檔測試。doctest是python里面自帶的一個模塊,它實際上是單元測試的一種。
官方解釋:doctest 模塊會搜索那些看起來像交互式會話的 Python 代碼片段,然后嘗試執(zhí)行并驗證結(jié)果

doctest測試用例可以放在兩個地方

  • 函數(shù)或者方法下的注釋里面

  • 模塊的開頭

案例

先看第一個案例,將需要測試的片段,標(biāo)準(zhǔn)格式,需要運(yùn)行的代碼前面加>>> ,相當(dāng)于進(jìn)入cmd這種交互環(huán)境執(zhí)行,期望的結(jié)果前面不需要加>>>

>>> multiply(4, 3)    12 >>> multiply('a', 3)    'aaa'

放到multiply函數(shù)的注釋里

def multiply(a, b):    """    fuction: 兩個數(shù)相乘    >>> multiply(4, 3)    12    >>> multiply('a', 3)    'aaa'    """    return a * b if __name__ == '__main__':    import doctest    doctest.testmod(verbose=True)

運(yùn)行結(jié)果

Trying:    multiply(4, 3) Expecting:    12 ok Trying:    multiply('a', 3) Expecting:    'aaa' ok 1 items had no tests:    __main__ 1 items passed all tests:   2 tests in __main__.multiply 2 tests in 2 items. 2 passed and 0 failed. Test passed.

從運(yùn)行的結(jié)果可以看出,雖然函數(shù)下方的注釋里面有其它內(nèi)容“fuction: 兩個數(shù)相乘”,但不會去執(zhí)行,只識別“>>>”這種符號。2個測試用例都是通過的,實際的結(jié)果與期望的結(jié)果一致。

失敗案例

doctest的內(nèi)容放到.py模塊的開頭也是可以識別到的

# 保存為xxx.py ''' fuction: 兩個數(shù)相乘 >>> multiply(4, 8) 12 >>> multiply('a', 5) 'aaa' ''' def multiply(a, b):    """    fuction: 兩個數(shù)相乘    """    return a * b if __name__ == '__main__':    import doctest    doctest.testmod(verbose=True)

運(yùn)行結(jié)果2個都失敗

********************************************************************** 1 items had failures:   2 of   2 in __main__ 2 tests in 2 items. 0 passed and 2 failed. ***Test Failed*** 2 failures.

verbose參數(shù),設(shè)置為True則在執(zhí)行測試的時候會輸出詳細(xì)信息

cmd執(zhí)行

以上案例是在編輯器直接運(yùn)行的,如果在cmd里面,也可以用指令去執(zhí)行

$ python -m doctest -v xxx.py

  • m 參數(shù)指定運(yùn)行方式doctest

  • -v參數(shù)是verbose,帶上-v參數(shù)相當(dāng)于verbose=True

pytest運(yùn)行

pytest框架是可以兼容doctest用例,執(zhí)行的時候加個參數(shù) —doctest-modules ,這樣它就能自動搜索到doctest的用例

$ pytest -v —doctest-modules  xxx.py

如下是函數(shù)下的文檔

fuction: 兩個數(shù)相乘 >>> multiply(4, 3) 12 >>> multiply('a', 5) 'aaa'

運(yùn)行結(jié)果

D:\test1122\a>pytest -v --doctest-modules  xxx.py ============================= test session starts ============================= platform win32 -- Python 3.6.0, pytest-3.6.3, py-1.5.4, pluggy-0.6.0 -- d:\softpython3.6\python.exe cachedir: .pytest_cache metadata: {'Python': '3.6.0', 'Platform': 'Windows-7-6.1.7601-SP1', 'Packages': {'pytest': '3.6.3', 'py': '1.5.4', 'pluggy': '0.6.0'}, 'Plugins': {'metadata': ' 1.7.0', 'html': '1.19.0', 'allure-adaptor': '1.7.10'}, 'JAVA_HOME': 'D:\\soft\\j dk18\\jdk18v'} rootdir: D:\test1122\a, inifile: plugins: metadata-1.7.0, html-1.19.0, allure-adaptor-1.7.10 collected 1 item xxx.py::xxx.multiply FAILED                                              [100%] ================================== FAILURES =================================== ___________________________ [doctest] xxx.multiply ____________________________ 004 005     fuction: 兩個數(shù)相乘 006     >>> multiply(4, 3) 007     12 008     >>> multiply('a', 5) Expected:    'aaa' Got:    'aaaaa' D:\test1122\a\xxx.py:8: DocTestFailure ========================== 1 failed in 0.16 seconds ===========================

結(jié)果可以看出,文檔里面的每一行都被執(zhí)行了,當(dāng)遇到測試不通過的用例時,就不會繼續(xù)往下執(zhí)行了

doctest獨立文件

doctest內(nèi)容也可以和代碼抽離開,單獨用一個.txt文件保存

在當(dāng)前xxx.py同一目錄新建一個xxx.txt文件,寫入測試的文檔,要先導(dǎo)入該功能,導(dǎo)入代碼前面也要加>>>

>>> from xxx import multiply >>> multiply(4, 3) 12 >>> multiply('a', 3) 'aaa'

cmd執(zhí)行“python -m doctest -v  xxx.txt測試結(jié)果

>python -m doctest -v  xxx.txt Trying:    from xxx import multiply Expecting nothing ok Trying:    multiply(4, 3) Expecting:    12 ok Trying:    multiply('a', 3) Expecting:    'aaa' ok 1 items passed all tests:   3 tests in xxx.txt 3 tests in 1 items. 3 passed and 0 failed. Test passed.

** 作者:上海-悠悠 QQ交流群:588402570**

    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多