Python单元测试模块doctest的具体使用


Posted in Python onFebruary 10, 2020

开发高质量软件的过程中,我们经常会为每个函数编写测试,这样在开发过程中运行这些测试的时候就比较方便,doctest是一个python标准库自带的轻量单元测试工具,适合实现一些简单的单元测试。

doctest模块提供的这样的工具,用于扫描模块并验证程序文档字符串中嵌入的测试,在docstring中寻找到测试用例并执行,比较输出结果与期望值是否符合。

我们如何构造这些测试呢?很简单

在python的交互解释器中创建测试用例,并复制到docstring中

tip:doctest在docstring中寻找测试用例的时候,认为>>>是一个测试用例的开始,直到遇到空行或者下一个>>>,在两个测试用例之间有其他内容的话,会被doctest忽略(可以利用这个特性为测试用例编写一些注释)。

我先在我自己的项目下准备一个测试脚本quality_q.py:

def average(values):
  """Computes the arithmetic mean of a list of numbers.

  >>> print(average([20, 30, 70]))
  40.0
  """
  return sum(values) / len(values)


#
if __name__ == '__main__':
  import doctest
  doctest.testmod(verbose=True) # automatically validate the embedded tests
  # 那个verbose参数,如果设置为True则在执行测试的时候会输出详细信息。
  # 默认是False,表示运行测试时,只有失败的用例会输出详细信息,成功的测试用例不会输入任何信息。

启动测试的方法:

第一个是在__main__函数中调用了doctest.testmod()方法。
然后在交互解释器中执行运行脚本 python3 doctest_q.py

如果__main__函数有其他用途,不方便调用doctest.testmod()方法,那么可以用另外一种执行测试的方法:

在交互解释器中执行如下命令执行测试: python3 -m doctest doctest_q.py -v
这里 -m 表示引用一个模块,-v 等价于 verbose=True

因为我是在Pycharm中创建的文件,我就直接打开Pycharm的Terminal,然后在交互解释器中切换一下脚本目录,执行的上面说到的启动方式,(顺便复习一下os模块的常用操作)
ps:读者在测试自己的例子时只需注意一下自己的当前工作目录即可

看一下最后的结果:

➜ ForF python3
Python 3.7.3 (default, Mar 27 2019, 09:23:15)
[Clang 10.0.1 (clang-1001.0.46.3)] on darwin
Type "help", "copyright", "credits" or "license" for more information.

>>> import os

>>> os.getcwd()
'/Users/dengjiguang/PycharmProjects/ForF'
>>> os.chdir('/Users/dengjiguang/PycharmProjects/ForF'+'/python_sample/quality_control')

>>> os.system('python3 -m doctest doctest_q.py -v')
Trying:
  print(average([20, 30, 70]))
Expecting:
  40.0
ok
1 items had no tests:
  doctest_q
1 items passed all tests:
  1 tests in doctest_q.average
1 tests in 2 items.
1 passed and 0 failed.
Test passed.
0
>>>

os.getcwd():返回当前的工作目录
os.chdir(‘path'):切换工作目录
os.system(‘command'): 执行系统shell命令

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python轻松查到删除自己的微信好友
Jan 10 Python
详解python中 os._exit() 和 sys.exit(), exit(0)和exit(1) 的用法和区别
Jun 23 Python
使用pygame模块编写贪吃蛇的实例讲解
Feb 05 Python
python pandas 对series和dataframe的重置索引reindex方法
Jun 07 Python
对Python subprocess.Popen子进程管道阻塞详解
Oct 29 Python
selenium在执行phantomjs的API并获取执行结果的方法
Dec 17 Python
使用Python-OpenCV向图片添加噪声的实现(高斯噪声、椒盐噪声)
May 28 Python
Python 实现一个手机号码获取妹子名字的功能
Sep 25 Python
Pytorch实现神经网络的分类方式
Jan 08 Python
python-docx文件定位读取过程(尝试替换)
Feb 13 Python
浅谈Pycharm的项目文件名是红色的原因及解决方式
Jun 01 Python
Python超简单容易上手的画图工具库推荐
May 10 Python
简单了解django文件下载方式
Feb 10 #Python
TensorFlow Saver:保存和读取模型参数.ckpt实例
Feb 10 #Python
tensorflow实现读取模型中保存的值 tf.train.NewCheckpointReader
Feb 10 #Python
解决tensorflow添加ptb库的问题
Feb 10 #Python
使用TensorFlow直接获取处理MNIST数据方式
Feb 10 #Python
python如何实现单链表的反转
Feb 10 #Python
基于python求两个列表的并集.交集.差集
Feb 10 #Python
You might like
ThinkPHP访问不存在的模块跳转到404页面的方法
2014/06/19 PHP
详细解读PHP的Yii框架中登陆功能的实现
2015/08/21 PHP
php集成动态口令认证
2016/07/21 PHP
Win7环境下Apache连接MySQL提示连接已重置的解决办法
2017/05/09 PHP
PHP设计模式(一)工厂模式Factory实例详解【创建型】
2020/05/02 PHP
javascript日期转换 时间戳转日期格式
2011/11/05 Javascript
input 输入框获得/失去焦点时隐藏/显示文字(jquery版)
2013/04/02 Javascript
基于jquery异步传输json数据格式实例代码
2013/11/23 Javascript
JS实现侧悬浮浮动实例代码
2013/11/29 Javascript
JS二维数组的定义说明
2014/03/03 Javascript
超链接的禁用属性Disabled使用示例
2014/07/31 Javascript
Js实现简单的小球运动特效
2016/02/18 Javascript
Jquery获取第一个子元素简单实例
2016/06/02 Javascript
深入理解JavaScript中的块级作用域、私有变量与模块模式
2016/10/31 Javascript
js实现复选框的全选和取消全选效果
2017/01/03 Javascript
ie下js不执行的几种可能
2017/02/28 Javascript
jQuery实现导航栏头部菜单项点击后变换颜色的方法
2017/07/19 jQuery
使用python编写android截屏脚本双击运行即可
2014/07/21 Python
Python中使用platform模块获取系统信息的用法教程
2016/07/08 Python
python操作excel的方法
2018/08/16 Python
python中selenium操作下拉滚动条的几种方法汇总
2019/07/14 Python
python文字转语音实现过程解析
2019/11/12 Python
Numpy之reshape()使用详解
2019/12/26 Python
浅析Python模块之间的相互引用问题
2021/02/26 Python
Move Free官方海外旗舰店:美国骨关节健康专业品牌
2017/12/06 全球购物
L’AGENCE官网:加州女装品牌
2018/06/03 全球购物
ESDlife健康生活易:身体检查预订、搜寻及比较
2019/05/10 全球购物
初中体育教学反思
2014/01/14 职场文书
材料员岗位职责
2014/03/13 职场文书
国窖1573广告词
2014/03/21 职场文书
教师教学评估方案
2014/05/09 职场文书
法定代表人身份证明书
2014/09/10 职场文书
销售员工作检讨书(推荐篇)
2014/10/18 职场文书
2016春季幼儿园大班开学寄语
2015/12/03 职场文书
解析Redis Cluster原理
2021/06/21 Redis
Android存储中最基本的文件存储方式
2022/04/30 Java/Android