python代码测试工具模块_详解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'
ok
Trying:
string_lower('ABC')
Expecting:
'abc'
ok
Trying:
string_lower('abc')
Expecting:
'abc'
ok
1 items had no tests:
test_string_lower
1 items passed all tests:
3 tests in test_string_lower.string_lower
3 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_lower
3 tests in 2 items.
0 passed and 3 failed.
***Test Failed*** 3 failures.
这时候,程序测试失败,它不仅捕捉到了bug,还清楚地指出错误出在什么地方。我们不难把这个程序修改过来。
关于doctest模块的更详细的使用说明,可以参考网址: https://docs.python.org/2/lib... 。
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 test
Fbegin test
F
======================================================================
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/lib... 。
总结
以上所述是小编给大家介绍的Python中的测试工具,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会技术回复大家的!
python代码测试工具模块_详解Python中的测试工具相关推荐
- python操作ppt的模块_详解 Python 操作 PPT 的各种骚操作!
1.python-pptx模块简介 使用python操作PPT,需要使用的模块就是python-pptx,下面来对该模块做一个简单的介绍. 这里提前做一个说明:python操作PPT,最好是我们提前设 ...
- python处理ppt 哪个模块_详解 Python 操作 PPT 的各种骚操作!
1.python-pptx模块简介 使用python操作PPT,需要使用的模块就是python-pptx,下面来对该模块做一个简单的介绍. 这里提前做一个说明:python操作PPT,最好是我们提前设 ...
- python代码执行过程记录_详解python程序中记录日志的方法
日志可以用来记录应用程序的状态.错误和信息消息,也经常作为调试程序的工具.它的重要性就不多说了,直接进入正题. python提供了一个标准的日志接口,就是logging模块.日志级别有DEBUG.IN ...
- python3 json模块_详解python 3.6 安装json 模块(simplejson)
JSON 相关概念: 序列化(Serialization):将对象的状态信息转换为可以存储或可以通过网络传输的过程,传输的格式可以是JSON,XML等.反序列化就是从存储区域(JSON,XML)读取反 ...
- python从random生成列表_详解Python利用random生成一个列表内的随机数
详解Python利用random生成一个列表内的随机数 首先,需要导入random模块: import random 随机取1-33之间的1个随机数,可能重复: random.choice(range ...
- python可以播放音乐吗_详解python播放音频的三种方法
第一种 使用pygame模块 pygame.mixer.init() pygame.mixer.music.load(self.wav_file) pygame.mixer.music.set_vol ...
- python策略模式包含角色_详解Python设计模式之策略模式
虽然设计模式与语言无关,但这并不意味着每一个模式都能在每一门语言中使用.<设计模式:可复用面向对象软件的基础>一书中有 23 个模式,其中有 16 个在动态语言中"不见了,或者简 ...
- python 线程安全的数据类型_详解python多线程、锁、event事件机制的简单使用
详解python多线程.锁.event事件机制的简单使用 发布时间:2020-09-25 02:04:12 来源:脚本之家 阅读:117 作者:君惜 线程和进程 1.线程共享创建它的进程的地址空间,进 ...
- python壁纸高清图片_详解Python静态网页爬取获取高清壁纸
前言 在设计爬虫项目的时候,首先要在脑内明确人工浏览页面获得图片时的步骤 一般地,我们去网上批量打开壁纸的时候一般操作如下: 1.打开壁纸网页 2.单击壁纸图(打开指定壁纸的页面) 3.选择分辨率(我 ...
最新文章
- 计算机考研b区国家线,考研b区国家线历年分数线情况
- php数组重复值销毁,如何从PHP中删除数组中的重复值
- java获取当前时间前一周、前一月、前一年的时间
- Java基础入门笔记-对象的销毁
- 1000道Python题库系列分享四(40道)
- 解决Hibernate4执行update操作,不更新数据的问题
- c# mysql datetime 判断为空 dbnull_转:SqlServer中的datetime类型的空值和c#中的DateTime的空值的...
- linux centos 系统php支持jpeg的安装方法
- 【NLP必读】2019年深度学习自然语言处理最新十大发展趋势
- 问题解决:Unlink of the file ‘.git/objects/pack/….idx’ failed. Should I try again?
- c语言程序设计基础第三版答案,清华大学出版社-图书详情-《C语言程序设计上机指导与习题解答(第3版)》...
- OpenSIPS Crash 宕机的初步解决办法(二)
- python cv2 绘制不规则形状的最小外接矩形、最大内接矩形、最大内接圆、最小外接圆、拟合椭圆
- HX711 压力调试 51程序
- Jenkins书籍推荐
- 生产型企业如何搭建进销存管理系统?低代码平台了解一下
- anywebp jpg png 转换webp格式图片 免费在线转换
- Flash builder 4无法调试问题
- win7计算机评分评不了,小编帮您win7系统无法给电脑硬件评分的恢复方案
- 导航电子地图制作甲级测绘资质
热门文章
- 微软开源项目NeuronBlocks - 像搭积木一样构建NLP深度学习模型
- 三招武林绝学带你玩转「强化学习」
- 14 篇论文为你呈现「迁移学习」研究全貌 | 论文集精选 #04
- 2020.10.04蓝桥测试
- KMP字符串搜索算法
- Fibonacci数列 矩阵快速幂
- 【☀️~爆肝万字总结递归~❤️玩转算法系列之我如何才能掌握递归解题的能力❤️~十大经典问题助你突破极限~建议收藏☀️】
- Spring Boot-@Conditional注解以及衍生注解@ConditionalOnBean
- 「中间件系列二」redis缓存
- 云效 Flow——Java构建并通过云效上传二方库到 Maven 私有仓库