作者:jclian,喜欢算法,热爱分享,希望能结交更多志同道合的朋友,一起在学习Python的道路上走得更远!

当我们在写程序的时候,我们需要通过测试来验证程序是否出错或者存在问题,但是,编写大量的测试来确保程序的每个细节都没问题会显得很繁琐。在Python中,我们可以借助一些标准模块来帮助我们自动完成测试过程,比如:

  • unittest: 一个通用的测试框架;

  • doctest: 一个更简单的模块,是为检查文档而设计的,但也非常适合用来编写单元测试。

  下面,笔者将会简单介绍这两个模块在测试中的应用。

doctest

  doctest模块会搜索那些看起来像是python交互式会话中的代码片段,然后尝试执行并验证结果。下面我们以doctest.testmod为例,函数doctest.testmod会读取模块中的所有文档字符串,查找看起来像是从交互式解释器中摘取的示例,再检查这些示例是否反映了实际情况。
  我们先创建示例代码文件test_string_lower.py,完整代码如下:

# -*- coding: utf-8 -*-

def string_lower(string):    '''    返回一个字符串的小写    :param string: type: str    :return: the lower of input string    >>> string_lower('AbC')    'abc'    >>> string_lower('ABC')    'abc'    >>> string_lower('abc')    'abc'    '''    return string.lower()

if __name__ == '__main__':    import doctest, test_string_lower    doctest.testmod(test_string_lower)

首先先对程序进行说明,函数string_lower用于返回输入字符串的小写,函数中的注释中,一共包含了3个测试实例,期望尽可能地包含各种测试情况,接着在主函数中导入doctest, test_string_lower,再运行doctest中的testmod函数即可进行测试。
  接着,我们开始测试。首先,在命令行中输入python test_string_lower.py,运行后会发现什么都没有输出,但这其实是件好事,它表明程序中的所有测试都通过了!那么,如果我们想要获得更多的输出呢?可在运行脚本的时候增加参数-v,这时候命令变成python test_string_lower.py -v,输出的结果如下:

Trying:    string_lower('AbC')Expecting:    'abc'okTrying:    string_lower('ABC')Expecting:    'abc'okTrying:    string_lower('abc')Expecting:    'abc'ok1 items had no tests:    test_string_lower1 items passed all tests:   3 tests in test_string_lower.string_lower3 tests in 2 items.3 passed and 0 failed.Test passed.

可以看到,程序测试的背后还是发生了很多事。接着,我们尝试着程序出错的情况,比如我们不小心把函数的返回写成了:

return string.upper()

这其实是返回输入字符串的大写了,而我们测试的实例却返回了输入字符串的小写,再运行该脚本(加上参数-v),输出的结果如下:

Failed example:    string_lower('abc')Expected:    'abc'Got:    'ABC'1 items had no tests:    test_string_lower**********************************************************************1 items had failures:   3 of   3 in test_string_lower.string_lower3 tests in 2 items.0 passed and 3 failed.***Test Failed*** 3 failures.

这时候,程序测试失败,它不仅捕捉到了bug,还清楚地指出错误出在什么地方。我们不难把这个程序修改过来。
  关于doctest模块的更详细的使用说明,可以参考网址:https://docs.python.org/2/library/doctest.html 。

unittest

   unittest类似于流行的Java测试框架JUnit,它比doctest更灵活,更强大,能够帮助你以结构化的方式来编写庞大而详尽的测试集。
  我们以一个简单的示例入手,首先我们编写my_math.py脚本,代码如下:

# -*- coding: utf-8 -*-def product(x, y):    '''    :param x: int, float    :param y: int, float    :return:  x * y    '''    return x * y

该函数实现的功能为:输入两个数x, y, 返回这两个数的乘积。接着是test_my_math.py脚本,完整的代码如下:

import unittest, my_math

class ProductTestcase(unittest.TestCase):

    def setUp(self):        print('begin test')

    def test_integers(self):        for x in range(-10, 10):            for y in range(-10, 10):                p = my_math.product(x, y)                self.assertEqual(p, x*y, 'integer multiplication failed')

    def test_floats(self):        for x in range(-10, 10):            for y in range(-10, 10):                x = x/10                y = y/10                p = my_math.product(x, y)                self.assertEqual(p, x * y, 'integer multiplication failed')

if __name__ == '__main__':    unittest.main()

函数unittest.main负责替你运行测试:在测试方法前执行setUp方法,示例化所有的TestCase子类,并运行所有名称以test打头的方法。assertEqual方法检车指定的条件(这里是相等),以判断指定的测试是成功了还是失败了。
  接着,我们运行前面的测试,输出的结果如下:

begin test.begin test.----------------------------------------------------------------------Ran 2 tests in 0.001s

OK

可以看到,该程序运行了两个测试,每个测试前都会输出'begin test',.表示测试成功,若测试失败,则返回的是F
  接着模拟测试出错的情形,将my_math函数中的product方法改成返回:

return x + y

再运行测试脚本,输出的结果如下:

begin testFbegin testF======================================================================FAIL: test_floats (__main__.ProductTestcase)----------------------------------------------------------------------Traceback (most recent call last):  File "test_my_math.py", line 20, in test_floats    self.assertEqual(p, x * y, 'integer multiplication failed')AssertionError: -2.0 != 1.0 : integer multiplication failed

======================================================================FAIL: test_integers (__main__.ProductTestcase)----------------------------------------------------------------------Traceback (most recent call last):  File "test_my_math.py", line 12, in test_integers    self.assertEqual(p, x*y, 'integer multiplication failed')AssertionError: -20 != 100 : integer multiplication failed

----------------------------------------------------------------------Ran 2 tests in 0.001s

FAILED (failures=2)

两条测试都未通过,返回的是F,并帮助你指出了错误的地方,接下来,你应该能快速地修复这个bug。
  关于unittest模块的更加详细的说明,可以参考网址:https://docs.python.org/3/library/unittest.html 。

总结

  本文介绍了两个Python中的测试工具:doctest和unittest,并配以简单的例子来说明这两个测试模块的使用方法,希望能对读者有所帮助~

▼ 点击成为社区注册会员          「在看」一下,一起PY!

python 两个[]_Python中的两个测试工具相关推荐

  1. 4.1 [单选]两化融合中的两化是指 - 关于两化融合(主讲:凌捷)笔记

    [单选]两化融合中的两化是指

  2. exce中让两列数据一一对应_EXCEL表格如何匹配两列数据一样-EXCEL让两个表格中的两列数据一一对应...

    怎样把excel中两列有部分相同的数据进行匹配? 1.首先打开excel表格,可以看到有两列数据需要匹配,找出列B中在列A中没有的数据. 2.然后在C1单元格内输入函数公式:=IF(ISNA(VLOO ...

  3. python list合并_python中如何合并两个列表

    python合并列表的方法如下: 方法一 最原始,最笨的方法,分别从两个列表中取出所有的元素,再放入新列表中就OK了.示例代码如下:list1 = [1,2,3] list2 = [4,5,6] li ...

  4. python里什么叫子图_Python中的两个子图(matplotlib)

    我想在 Python中创建两个子图(使用Anaconda 2.7),但我编写的代码生成两个图,两者都没有显示太多. 这是代码: import pandas as pd import pandas.io ...

  5. python浮点数保留两位小数_python中保留两位小数怎么表示

    这里有三种方法, round(a,2) '%.2f' % a Decimal('5.000').quantize(Decimal('0.00')) 当需要输出的结果要求有两位小数的时候,字符串形式的: ...

  6. python图合并_Python图像处理实现两幅图像合成一幅图像的方法【测试可用】

    本文实例讲述了Python图像处理实现两幅图像合成一幅图像的方法.分享给大家供大家参考,具体如下: 将两幅图像合成一幅图像,是图像处理中常用的一种操作,python图像处理库PIL中提供了多种种将两幅 ...

  7. python图像检测_Python+Opencv识别两张相似图片

    在网上看到python做图像识别的相关文章后,真心感觉python的功能实在太强大,因此将这些文章总结一下,建立一下自己的知识体系. 当然了,图像识别这个话题作为计算机科学的一个分支,不可能就在本文简 ...

  8. python赋值语句格式_Python中变量和变量赋值的几种形式

    动态类型的语言 python是动态类型的语言,不需要声明变量的类型. 实际上,python中的变量仅仅只是用来保存一个数据对象的地址.无论是什么数据对象,在内存中创建好数据对象之后,都只是把它的地址保 ...

  9. python map用法_Python中ChainMap的一种实用用法

    Python部落(python.freelycode.com)组织翻译,禁止转载,欢迎转发. 简而言之ChainMap:将多个字典视为一个,解锁Python超能力. Python标准库中的集合模块包含 ...

最新文章

  1. 这是给程序员专用的书吗?
  2. Linux上搭建nginx,及简单配置
  3. 我往手里面植入了一枚芯片,但并没有获得超能力
  4. 解决utf8编码的php生成csv打开乱码的问题
  5. 禅与维修摩托车的艺术_罗伯特-M-波西格
  6. 用友软件计算机时间格式,如何正确设置系统日期格式?_速达软件_用友,速达,管家婆,微软,金蝶,方正,博世通,数据博士,进销存,财务软件-飞鸿软件帮助中心 -...
  7. RabbitMQ实现订单30分钟超时自动关闭
  8. 让你立刻爱上数学的10个算术游戏
  9. css的侧重点(2021.7.11)
  10. 正弦稳态电路的阻抗和功率
  11. 容器云技术docker
  12. HTTP_Wireshark
  13. java创建对象的过程详解
  14. 艰难的起步---微信小程序访问MSSQL数据库实例
  15. 基于JAVA红河旅游信息服务系统计算机毕业设计源码+系统+mysql数据库+lw文档+部署
  16. java checkbox数组_Java通过复选框控件数组实现添加多个复选框控件
  17. QGIS中怎样实现数据坐标系转换
  18. SLG项目开发经验二_大地图设计与实现
  19. Ps--钢笔工具(1)
  20. CB一体机添加客户机租户

热门文章

  1. “让Keras更酷一些!”:分层的学习率和自由的梯度
  2. CVPR 2018现场见闻
  3. stolz定理考研能用吗_重磅,考研数学最后重点预测
  4. springboot+springsecurity+mybatis plus之用户认证
  5. JAVA——操场跑步路径定位模拟解决方案
  6. Spring Boot——LocalDateTime格式化配置
  7. MySQL——排序查询
  8. 面试必问,如何控制多个线程的执行顺序
  9. R-3.1.1 编译安装2
  10. Python实训day06am【网络爬虫(爬取接口)】