Python中的断言用起来非常简单,你可以在assert
后面跟上任意判断条件,如果断言失败则会抛出异常。
-
>>> assert 1 + 1 == 2
-
>>> assert isinstance('Hello', str)
-
>>> assert isinstance('Hello', int)
-
Traceback (most recent call last):
-
File "<input>", line 1, in <module>
-
AssertionError
其实assert
看上去不错,然而用起来并不爽。就比如有人告诉你程序错了,但是不告诉哪里错了。很多时候这样的assert
还不如不写,写了我就想骂娘。直接抛一个异常来得更痛快一些。
改进方案 #1
一个稍微改进一丢丢的方案就是把必要的信息也放到assert
语句后面,比如这样。
-
>>> s = "nothin is impossible."
-
>>> key = "nothing"
-
>>> assert key in s, "Key: '{}' is not in Target: '{}'".format(key, s)
-
Traceback (most recent call last):
-
File "<input>", line 1, in <module>
-
AssertionError: Key: 'nothing' is not in Target: 'nothin is impossible.'
看上去还行吧,但是其实写的很蛋疼。假如你是一名测试汪,有成千上万的测试案例需要做断言做验证,相信你面对以上做法,心中一定有千万只那种马奔腾而过。
改进方案 #2
不管你是你是搞测试还是开发的,想必听过不少测试框架。你猜到我要说什么了吧?对,不用测试框架里的断言机制,你是不是洒。
py.test
py.test 是一个轻量级的测试框架,所以它压根就没写自己的断言系统,但是它对Python自带的断言做了强化处理,如果断言失败,那么框架本身会尽可能多地提供断言失败的原因。那么也就意味