发布时间:2019-07-30 09:44:56编辑:auto阅读(1293)
文档测试
如果你经常阅读Python的官方文档,可以看到很多文档都有示例代码。比如re模块就带了很多示例代码:
>>>import re
>>>m = re.search('(?<=abc)def','abcdef')
>>>m.group(0)
'def'
这些文档和其他说明可以写在注释中,然后,由一些工具来自动生成文档。既然这些代码本身可以粘贴出来直接运行,那么可不可以自动执行这些写在注释中的代码呢?
答案是肯定的。
当我们如果编写注释时,写上这样的注释:
def abs(n):
'''
Function to get absolute value of number.
Example:
>>>abs(1)
1
>>>abs(-1)
1
>>>abs(0)
0
'''
return n if n >=0 else(-n)
无疑更明确的告诉函数调用者该函数期望的输入和输出。
并且,Python内置的‘文档测试(doctest)’模块会直接提取注释中的代码并执行测试。
doctest严格按照Python交互式命令行的输入和输出判断测试结果是否正确。只有测试异常的时候,可以用...一大段烦人的输出。
让我们用doctest来测试我们上次编写的Dict类:
# mydict2.py class Dict(dict): ''' Simple dict but also support access as x.y style. >>> d1 = Dict() >>> d1['x'] = 100 >>> d1.x 100 >>> d1.y = 200 >>> d1['y'] 200 >>> d2 = Dict(a=1, b=2, c='3') >>> d2.c '3' >>> d2['empty'] Traceback (most recent call last): ... KeyError: 'empty' >>> d2.empty Traceback (most recent call last): ... AttributeError: 'Dict' object has no attribute 'empty' ''' def __init__(self, **kw): super(Dict, self).__init__(**kw) def __getattr__(self, key): try: return self[key] except KeyError: raise AttributeError(r"'Dict' object has no attribute '%s'" % key) def __setattr__(self, key, value): self[key] = valueif __name__=='__main__': import doctest doctest.testmod()
运行Python mydict2.py
什么输出也没有,说明我们编写的docttest都是正确的。如果程序有问题,比如,将__getattr__()方法注释掉,在运行就会报错:
$ python3 mydict2.py ********************************************************************** File "/Users/michael/Github/learn-python3/samples/debug/mydict2.py", line 10, in __main__.Dict Failed example: d1.x Exception raised: Traceback (most recent call last): ... AttributeError: 'Dict' object has no attribute 'x' ********************************************************************** File "/Users/michael/Github/learn-python3/samples/debug/mydict2.py", line 16, in __main__.Dict Failed example: d2.c Exception raised: Traceback (most recent call last): ... AttributeError: 'Dict' object has no attribute 'c' ********************************************************************** 1 items had failures: 2 of 9 in __main__.Dict ***Test Failed*** 2 failures.
关注最后3行代码,当模块正常导入时,doctest不会被执行。只有在命令直接运行时,才执行doctest。所以,不必担心doctest会在非测试环境下被运行。
小结:
doctest非常有用,不但可以用来测试,还可以直接作为示例代码。通过某些文档生成工具,就可以自动把包含doctest的注释提取出来。同时也看到了doctest。
上一篇: python getopt使用
下一篇: 安装H3C的各种问题
47487
45791
36787
34320
28957
25592
24438
19608
19106
17630
5460°
6044°
5567°
5634°
6569°
5373°
5372°
5880°
5853°
7165°