1. 程式人生 > >Python 各種測試框架簡介(三):nose

Python 各種測試框架簡介(三):nose

調用 QQ upm href 命令 math 一點 發現 方法

轉載:https://blog.csdn.net/qq_15013233/article/details/52527260 摘要 這裏將從(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:python
from 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:python
from nose import with_setup 
from unnecessary_math import multiply

def setup_module(module):
    print(‘setup_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 ... ok
test.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 也適用。

Python 各種測試框架簡介(三):nose