Python Nose框架編寫測試用例方法
1. 關于Nose
nose項目是于2005年發(fā)布的,也就是 py.test改名后的一年。它是由 Jason Pellerin 編寫的,支持與 py.test 相同的測試習慣做法,但是這個包更容易安裝和維護。
nose的口號是:擴展unittest,nose讓測試更簡單!
nose官網(wǎng):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)的函數(shù)或類,并且所在的模塊也匹配該表達式,都會被識別為測試并執(zhí)行。
出于對unittest兼容性的考慮,nose也支持繼承unittest.TestCase的子類測試用例。與py.test類似,nose按照測試集在模塊文件中出現(xiàn)的順序執(zhí)行功能測試。繼承于TestCase的測試集和測試類按照字母表順序執(zhí)行。
2.1 Fixtures
nose支持包,模塊,類和函數(shù)例級別的Fixtures(setup和teardown方法,用以自動測試的初始化或者清理工作)
2.2 Test packages
nose允許測試例以包的方式分組。
因此,也需要包級別的setup;比如,如果你想要創(chuàng)建一個數(shù)據(jù)庫測試,你可能會想要在包setup時創(chuàng)建數(shù)據(jù)庫,當每個測試結束之后運行包teardown時,銷毀它。而不是在每一個測試模塊或者測試例中創(chuàng)建和銷毀數(shù)據(jù)庫。
想要創(chuàng)建包級別的setup和teardown函數(shù),你需要在測試包的_ init_.py 函數(shù)中定義setup和teardown函數(shù)。setup函數(shù)可以被命名為setup,setup_package,setUp,或者setUpPackage;teardown可以被命名為teardown,teardown_package, tearDown, 或者tearDownPackage。一旦第一個測試模塊從測試包中被加載后,一個包中的測試例就開始執(zhí)行。
2.3 Test modules
Test modules是一個匹配testMatch的python模塊。
測試模塊提供模塊級別的setup和teardown。可以定義setup, setup_module, setUp, setUpModule用于setup,teardown, teardown_module, tearDownModule用于teardown。一旦一個模塊中所有的用例被收集完后,模塊中的測試就開始執(zhí)行。
2.4 Test classes
Test classes是模塊中定義的匹配testMatch或者繼承unittest.TestCase的類。
所有的測試類以相同方式運行:通過testMatch匹配的找到類中的方法,并以全新的測試類實例運行測試方法。
像繼承于unittest.TestCase的子類一樣,測試類可以定義setUp tearDown函數(shù),它們將會分別在每一個測試方法之前和之后運行。類級別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
測試函數(shù)也可定義setup和teardown屬性,它們將會在測試函數(shù)開始和結束的時候運行。還可以使用@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支持生成器測試函數(shù)和測試方法。如下:
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
上述代碼執(zhí)行五次測試。nose生成迭代器,創(chuàng)建一個函數(shù)測試用例包,包裝每一個yield tuple。
Test generators必須yield tuples,且第一個元素必須是可調(diào)用的函數(shù),其他的元素作為參數(shù)傳遞。
Test generators測試用例默認名稱是函數(shù)或方法的名字+參數(shù)。如果你想要顯示不同的名稱,可以設置yield函數(shù)的description屬性。
Test generators中定義的setup和teardown函數(shù)僅僅會被執(zhí)行一次。若想對于每一個yield的用例都執(zhí)行,可將setup和teardown屬性設置到被yield的函數(shù)中,或者yield一個帶有setup和teardown屬性的可調(diào)用對象的實例。
比如:
@with_setup(setup_func, teardown_func) def test_generator(): # ... yield func, arg, arg # ...
上面的例子中,setup和teardown只會被執(zhí)行一次。與此相比:
def test_generator(): # ... yield func, arg, arg # ... @with_setup(setup_func, teardown_func) def func(arg): assert something_about(arg)
這個例子中,setup和teardown函數(shù)將會在每一次yield中執(zhí)行。
對于生成器方法,class中的setUp和tearDown方法將會在每一個生成的測試用例之前或者之后運行。setUp和tearDown方法并不會在生成器方法本身 之前運行,這就導致在第一個用例運行之前setUp運行兩次,之間卻沒有tearDown運行。
請注意,unittest.TestCase子類不支持Test generators方法。
總結
以上所述是小編給大家介紹的Python Nose框架編寫測試用例方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關文章
Python如何用NumPy讀取和保存點云數(shù)據(jù)
這篇文章主要介紹了Python如何用NumPy讀取和保存點云數(shù)據(jù),文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下2022-08-08python中l(wèi)ist*n生成多維數(shù)組與for循環(huán)生成多維數(shù)組的區(qū)別說明
這篇文章主要介紹了python中l(wèi)ist*n生成多維數(shù)組與for循環(huán)生成多維數(shù)組的區(qū)別說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-05-05