国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

python 測試框架nose

2019-11-11 06:14:32
字體:
來源:轉載
供稿:網友

摘要 這里將從(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

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 方法執行于本類中每條用例之前')

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

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

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

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

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


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 临洮县| 辽宁省| 湘潭县| 长宁县| 屯留县| 仁布县| 洮南市| 贵州省| 原平市| 南澳县| 横山县| 象州县| 潜山县| 湘潭市| 保康县| 商河县| 商南县| 中江县| 吴旗县| 阿巴嘎旗| 罗源县| 新余市| 抚州市| 广汉市| 霍城县| 芦溪县| 炉霍县| 舟山市| 凤冈县| 沾益县| 读书| 延吉市| 百色市| 麻栗坡县| 库尔勒市| 金昌市| 高阳县| 商城县| 涟源市| 鄂托克旗| 瑞金市|