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

本篇將介紹的 nose 再也不是 Python 官方發行版的標準包,但它與 unittest 有着千絲萬縷的聯繫。好比 nose 的口號就是:python

擴展 unittest,nose 讓測試更簡單。正則表達式

##簡單在哪

自古(1970)以來,任何標榜「更簡單」的工具所使用的手段基本都是隱藏細節,nose 也不例外。nose 不使用特定的格式、不須要一個類容器,甚至不須要 import nose ~(這也就意味着它在寫測試用例時不須要使用額外的 api)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:code

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 規則爲:ip

  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 也適用。文檔

相關文章
相關標籤/搜索