詳細(xì)說(shuō)明Python 操作符風(fēng)格
調(diào)用方法會(huì)影響可讀性。盡管 assertEqual() 方法名能夠表明要測(cè)試兩個(gè)值是否相等,但是代碼看起來(lái)仍然不像是比較,對(duì)于熟悉Python 操作符的開(kāi)發(fā)人員,不如 Python 操作符那么明確。
第二,正如在本系列的第三篇文章中將看到的,新的測(cè)試框架現(xiàn)在知道如何檢查 assert 語(yǔ)句,從而查明造成測(cè)試失敗的條件。這意味著簡(jiǎn)單的 assert 語(yǔ)句現(xiàn)在能夠產(chǎn)生有意義的測(cè)試失敗消息。
它提供的信息與調(diào)用 assertEqual() 等老方法的結(jié)果差不多。***,即使 assertEqual() 仍然是必要的,但是從測(cè)試模塊導(dǎo)入這個(gè)函數(shù)(而不是通過(guò)類繼承讓函數(shù)可用)肯定更簡(jiǎn)單,更符合 Python 操作符的風(fēng)格。
實(shí)際上,在下面會(huì)看到,當(dāng) py.test 和 nose 要提供更多用來(lái)支持測(cè)試的例程時(shí),它們只需把這些例程定義為函數(shù),然后用戶可以把這些函數(shù)導(dǎo)入自己的代碼。當(dāng)然,如果作者確實(shí)需要通過(guò)例程緩存狀。
- # nose.tools support functions for writing tests
- assert_almost_equal(first, second, places=7, msg=None)
- assert_almost_equals(first, second, places=7, msg=None)
- assert_equal(first, second, msg=None)
- assert_equals(first, second, msg=None)
- assert_false(expr, msg=None)
- assert_not_almost_equal(first, second, places=7, msg=None)
- assert_not_almost_equals(first, second, places=7, msg=None)
- assert_not_equal(first, second, msg=None)
- assert_not_equals(first, second, msg=None)
- assert_true(expr, msg=None)
- eq_(a, b, msg=None)
- ok_(expr, msg=None)
但是,如果程序員希望編寫簡(jiǎn)單的測(cè)試代碼,不愿意考慮 doctest 涉及的亂七八糟的東西,那么測(cè)試函數(shù)是很好的方法。總之,測(cè)試函數(shù)可以極大地增強(qiáng)編寫測(cè)試的簡(jiǎn)便性。程序員不需要記住、重寫或復(fù)制以前編寫的測(cè)試代碼,新的約定讓 Python 程序員能夠像編寫一般Python 操作符一樣編寫測(cè)試:只需打開(kāi)一個(gè)空文件,然后輸入!
py.test 和 nose 框架都提供特殊的例程,這些例程可以簡(jiǎn)化測(cè)試的編寫。可以認(rèn)為它們分別提供一種方便的測(cè)試 “方言”,可以用這些 “方言” 編寫測(cè)試。這會(huì)簡(jiǎn)化測(cè)試的編寫并減少錯(cuò)誤,還會(huì)使測(cè)試更簡(jiǎn)短、可讀性更好。
但是,使用這些例程還會(huì)導(dǎo)致一個(gè)重要的后果:您的測(cè)試與提供函數(shù)的框架捆綁在一起了,喪失了兼容性。因此,要權(quán)衡考慮方便性和兼容性。如果只使用笨拙的標(biāo)準(zhǔn)Python 操作符unittest 模塊從頭編寫所有測(cè)試,那么它們能夠在任何測(cè)試框架中運(yùn)行。
更進(jìn)一步,如果采用簡(jiǎn)單的做法編寫測(cè)試函數(shù)(如上所述),那么測(cè)試至少能夠在 py.test 和 nose 中運(yùn)行。但是。如果開(kāi)始使用某個(gè)測(cè)試框架特有的特性,那么如果以后另一個(gè)框架開(kāi)發(fā)出了新的重要特性,您決定進(jìn)行框架遷移,就必須重寫測(cè)試。
py.test 和 nose 都為 TestCase 的 assertRaises() 方法提供了替代品。py.test 提供的版本比較新穎,它也可以接受要執(zhí)行的字符串,這更強(qiáng)大,因?yàn)榭梢詼y(cè)試引發(fā)異常的表達(dá)式,而不只是函數(shù)調(diào)用:
- # conveniences.py
- import math
- import py.test
- py.test.raises(OverflowError, math.log, 0)
- py.test.raises(ValueError, math.sqrt, -1)
- py.test.raises(ZeroDivisionError, "1 / 0")
- import nose.tools
- nose.tools.assert_raises(OverflowError, math.log, 0)
- nose.tools.assert_raises(ValueError, math.sqrt, -1)
- # No equivalent for third example!
在處理浮點(diǎn)數(shù)時(shí),如果希望測(cè)試能夠靈活地對(duì)待Python 操作符實(shí)現(xiàn),允許對(duì)浮點(diǎn)數(shù)的處理有細(xì)小的誤差,那么上面檢查近似值的例程尤其有意義。
【編輯推薦】