摘要 這里將從(pythontesting.net)陸續編譯四篇 Python 測試框架的簡介,分別為:doctest、unittest、nose 和 pytest。本篇為第三篇:nose
本篇將介紹的 nose 不再是 Python 官方發行版的標準包,但它與 unittest 有著千絲萬縷的聯系。比如 nose 的口號就是:
擴展 unittest,nose 讓測試更簡單。 簡單在哪 --------------------------------------------------------------------------------
自古(1970)以來,任何標榜“更簡單”的工具所使用的手段基本都是隱藏細節,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__ 函數都不用。這里唯一需要一點“講究”的語法在于,測試用例的命名仍需以 test_ 開頭。 <br /> 運行 nose --------------------------------------------------------------------------------
nose 在安裝的時候也向你 Python 根目錄下的 Scripts 文件夾內添加了一個名為 nosetests 的可執行文件,這個可執行文件就是用來執行測試的命令;當然你也仍可以使用 -m 參數來調用 nose 模塊: $ nosetests test.py$ python -m nose test.py··------------------------------------------------Ran 2 tests in 0.001s
OK 另外非常棒的一點是,nosetests 兼容對 doctest 和 unittest 測試腳本的解析運行。如果你認為 nose 比那兩個都好用的話,完全可以放棄 doctest 和 unittest 的使用。 <br /> 測試環境 --------------------------------------------------------------------------------
由于擴展自 unittest,nose 也支持類似于 setUp() setUpClass() setUpModule() 的測試環境創建方式,只不過函數命名規則最好改一改,我們可以使用更符合 Python 規范的命名規則。另外因為 nose 支持上例中所展示的函數式測試用例,所以還有一種為單個函數創建運行環境的裝飾器可用。下面我們將使用一個例子來展示這四種功能的用法。 test.py: lang:pythonfrom nose import with_setup from unnecessary_math import multiply
新聞熱點
疑難解答