Python Nose框架編寫測試用例方法


1. 關於Nose

nose項目是於2005年發布的,也就是 py.test改名后的一年。它是由 Jason Pellerin 編寫的,支持與 py.test 相同的測試習慣做法,但是這個包更容易安裝和維護。

nose的口號是:擴展unittest,nose讓測試更簡單!

nose官網:http://nose.readthedocs.io/en/latest/index.html

使用nose框架進行Python項目的自動化測試,可以參考:http://www.cnblogs.com/liaofeifight/p/5148717.html

本文主要介紹nose框架編寫自動化測試用例的方法。

2. Nose編寫測試用例方法

nose會自動識別源文件,目錄或包中的測試用例。

任何匹配testMatch正則表達式(默認為(?:^|[\b_\.-])[Tt]est,在一個單詞的邊界處或者緊跟-或_處有test或Test)的函數或類,並且所在的模塊也匹配該表達式,都會被識別為測試並執行。

出於對unittest兼容性的考慮,nose也支持繼承unittest.TestCase的子類測試用例。與py.test類似,nose按照測試集在模塊文件中出現的順序執行功能測試。繼承於TestCase的測試集和測試類按照字母表順序執行。

2.1 Fixtures

nose支持包,模塊,類和函數例級別的Fixtures(setup和teardown方法,用以自動測試的初始化或者清理工作)

2.2 Test packages

nose允許測試例以包的方式分組。

因此,也需要包級別的setup;比如,如果你想要創建一個數據庫測試,你可能會想要在包setup時創建數據庫,當每個測試結束之后運行包teardown時,銷毀它。而不是在每一個測試模塊或者測試例中創建和銷毀數據庫。

想要創建包級別的setup和teardown函數,你需要在測試包的_ init_.py 函數中定義setup和teardown函數。setup函數可以被命名為setup,setup_package,setUp,或者setUpPackage;teardown可以被命名為teardown,teardown_package, tearDown, 或者tearDownPackage。一旦第一個測試模塊從測試包中被加載后,一個包中的測試例就開始執行。

2.3 Test modules

Test modules是一個匹配testMatch的python模塊。

測試模塊提供模塊級別的setup和teardown。可以定義setup, setup_module, setUp, setUpModule用於setup,teardown, teardown_module, tearDownModule用於teardown。一旦一個模塊中所有的用例被收集完后,模塊中的測試就開始執行。

2.4 Test classes

Test classes是模塊中定義的匹配testMatch或者繼承unittest.TestCase的類。

所有的測試類以相同方式運行:通過testMatch匹配的找到類中的方法,並以全新的測試類實例運行測試方法。

像繼承於unittest.TestCase的子類一樣,測試類可以定義setUp tearDown函數,它們將會分別在每一個測試方法之前和之后運行。類級別setup fixture可以被命名為setup_class, setupClass, setUpClass, setupAll, setUpAll;teardown被命名為teardown_class, teardownClass, tearDownClass, teardownAll, tearDownAll, 類級別setup和teardown必須是類方法(@classmethod)。

2.5 Test functions

模塊中任何匹配TestMatch的方法都將會被FunctionTestCase裝飾,然后以用例的方式運行。最簡單的失敗和成功的用例如下:

def test():
    assert False
def test():
    pass

測試函數也可定義setup和teardown屬性,它們將會在測試函數開始和結束的時候運行。還可以使用@with_setup裝飾器,該方式尤其適用於在相同的模塊中的許多方法需要相同的setup操作。

def setup_func():
    "set up test fixtures"
 
def teardown_func():
    "tear down test fixtures"
 
@with_setup(setup_func, teardown_func)
def test():
    "test ..."

6.Test generators

nose支持生成器測試函數和測試方法。如下:

def test_evens():
    for i in range(0, 5):
        yield check_even, i, i*3
 
def check_even(n, nn):
    assert n % 2 == 0 or nn % 2 == 0

 

上述代碼執行五次測試。nose生成迭代器,創建一個函數測試用例包,包裝每一個yield tuple。

Test generators必須yield tuples,且第一個元素必須是可調用的函數,其他的元素作為參數傳遞。

Test generators測試用例默認名稱是函數或方法的名字+參數。如果你想要顯示不同的名稱,可以設置yield函數的description屬性。

Test generators中定義的setup和teardown函數僅僅會被執行一次。若想對於每一個yield的用例都執行,可將setup和teardown屬性設置到被yield的函數中,或者yield一個帶有setup和teardown屬性的可調用對象的實例。

比如:

@with_setup(setup_func, teardown_func)
def test_generator():
    # ...
    yield func, arg, arg # ...

 

上面的例子中,setup和teardown只會被執行一次。與此相比:

def test_generator():
    # ...
    yield func, arg, arg # ...
 
@with_setup(setup_func, teardown_func)
def func(arg):
    assert something_about(arg)

 

這個例子中,setup和teardown函數將會在每一次yield中執行。

對於生成器方法,class中的setUp和tearDown方法將會在每一個生成的測試用例之前或者之后運行。setUp和tearDown方法並不會在生成器方法本身 之前運行,這就導致在第一個用例運行之前setUp運行兩次,之間卻沒有tearDown運行。

請注意,unittest.TestCase子類不支持Test generators方法。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM