麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > Python > 正文

python 測試框架nose

2019-11-11 05:43:40
字體:
供稿:網(wǎng)友

摘要 這里將從(pythontesting.net)陸續(xù)編譯四篇 Python 測試框架的簡介,分別為:doctest、unittest、nose 和 pytest。本篇為第三篇:nose 

本篇將介紹的 nose 不再是 Python 官方發(fā)行版的標準包,但它與 unittest 有著千絲萬縷的聯(lián)系。比如 nose 的口號就是: 

擴展 unittest,nose 讓測試更簡單。 簡單在哪 --------------------------------------------------------------------------------

自古(1970)以來,任何標榜“更簡單”的工具所使用的手段基本都是隱藏細節(jié),nose 也不例外。nose 不使用特定的格式、不需要一個類容器,甚至不需要 import nose ~(這也就意味著它在寫測試用例時不需要使用額外的 api) 前兩篇中一直使用的 unnecessary_math.py 的 nose 版測試用例是這樣子的: lang:pythonfrom unnecessary_math import multiply

def test_numbers():    assert multiply(3,4)==12

def test_strings():    assert multiply('a',3)=='aaa' 看上去完全就是一個普通的模塊文件嘛,甚至連 __main__ 函數(shù)都不用。這里唯一需要一點“講究”的語法在于,測試用例的命名仍需以 test_ 開頭。 <br /> 運行 nose --------------------------------------------------------------------------------

nose 在安裝的時候也向你 Python 根目錄下的 Scripts 文件夾內(nèi)添加了一個名為 nosetests 的可執(zhí)行文件,這個可執(zhí)行文件就是用來執(zhí)行測試的命令;當然你也仍可以使用 -m 參數(shù)來調(diào)用 nose 模塊: $ nosetests test.py$ python -m nose test.py··------------------------------------------------Ran 2 tests in 0.001s

OK 另外非常棒的一點是,nosetests 兼容對 doctest 和 unittest 測試腳本的解析運行。如果你認為 nose 比那兩個都好用的話,完全可以放棄 doctest 和 unittest 的使用。 <br /> 測試環(huán)境 --------------------------------------------------------------------------------

由于擴展自 unittest,nose 也支持類似于 setUp() setUpClass() setUpModule() 的測試環(huán)境創(chuàng)建方式,只不過函數(shù)命名規(guī)則最好改一改,我們可以使用更符合 Python 規(guī)范的命名規(guī)則。另外因為 nose 支持上例中所展示的函數(shù)式測試用例,所以還有一種為單個函數(shù)創(chuàng)建運行環(huán)境的裝飾器可用。下面我們將使用一個例子來展示這四種功能的用法。 test.py: lang:pythonfrom nose import with_setup from unnecessary_math import multiply

def setup_module(module):   

def setup_deco():    print('setup_deco 將用于 with_setup')

def teardown_deco():    print('teardown_deco 也將用于 with_setup')

@with_setup(setup_deco,teardown_deco)def test_2b_decorated():    assert multiply(3,4)==12

class TestUM():    def setup(self):        print('setup 方法執(zhí)行于本類中每條用例之前')

    @classmethod    def setup_class(cls):        print('setup_class 類方法執(zhí)行于本類中任何用例開始之前,且僅執(zhí)行一次')

    def test_strings(self):        assert multiply('a',3)=='aaa' 運行 $ nosetests -v test.py 結(jié)果如下: test.TestUM.test_strings ... oktest.test_2b_decorated ... ok

---------------------------------------------------------------------Ran 2 tests in 0.002s

OK 我們的 print() 函數(shù)一點東西都沒打出來,如果你想看的話,給 nosetests 添加一個 -s 參數(shù)就可以了。 <br /> Test Discovery --------------------------------------------------------------------------------

nose 的 discovery 規(guī)則為: 1.長得像測試用例,那就是測試用例。路徑、模塊(文件)、類、函數(shù)的名字如果能和 testMatch 正則表達式匹配上,那就會被認為是一個用例。另外所有 unittest.TestCase 的子類也都會被當做測試用例。(這里的 testMatch 可能是個環(huán)境變量之類的東西,我沒有去查,因為反正你只要以 test_ 開頭的格式來命名就可以保證能被發(fā)現(xiàn))2.如果一個文件夾既長得不像測試用例,又不是一個包(路徑下沒有 __init__.py)的話,那么 nose 就會略過對這個路徑的檢查。3.但只要一個文件夾是一個包,那么 nose 就一定會去檢查這個路徑。4.顯式避免某個對象被當做測試用例的方法為:給其或其容器添加一個 __test__ 屬性,并且運算結(jié)果不為 True。并不需要直接指定為 False,只要 bool(__test__) == False 即可。另外,這個屬性的添加方式比較特別,確認自己已經(jīng)掌握使用方法前最好都試試。例如在類里面需要添加為類屬性而非實例屬性(即不能寫在 __inti__(self) 里),否則不起作用。這里因為只是簡介,就不挨個試了。(官方文檔里就沒解釋清楚...) 調(diào)用 discovery 的語法為,cd 到目錄后直接調(diào)用 $ nosetests,后面不跟具體的文件名。另外這種方法其實對 unittest 也適用。 ? 著作權(quán)歸作者所有


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 久久久久久久久久久高潮一区二区 | 羞羞视频一区二区 | 91真视频 | 99视频在线观看视频 | 免费黄色成人 | 海角在线观看91一区二区 | 99精品视频一区二区三区 | 亚洲一区二区观看播放 | 成人黄色短视频在线观看 | chinesehdxxxx无套| 亚洲精品v天堂中文字幕 | 大学生a级毛片免费视频 | 欧美日韩国产一区二区三区在线观看 | 久久精品一区二区三区四区五区 | 欧美日韩国产中文字幕 | 久章草在线视频 | 日本在线不卡一区二区 | av在线直播观看 | 一级做受毛片免费大片 | 九一免费国产 | 国产精品久久久久久久久久久久午夜 | 国产第一页精品 | 久草视频福利在线观看 | 麻豆91精品91久久久 | 日日草夜夜操 | av视在线 | 成人在线视频免费播放 | 欧美日韩国产成人在线观看 | 欧美一级黄色片在线观看 | 自拍亚洲伦理 | 久久精品欧美电影 | 久草在线资源视频 | 99riav视频一区二区 | 久久久www成人免费精品 | 午夜视频成人 | 九色中文 | av影院在线播放 | 色999中文字幕 | 国产一区二区久久精品 | 欧美成人黄色小视频 | 欧美伦理一区二区 |