单元测试工具(连载9)

简介: 单元测试工具(连载9)

3.2 unittest的测试覆盖率分析


利用coverage工具可以分析单元测试的覆盖率,首先我们通过pip命令下载coverage


pip install coverage

下载完毕,代开命令行编辑窗口,通过cd命令进入被测对象所在的目录,然后运行。


coverage run Calculatortest.py

这里Calculatortest.py为被测程序文件,测试程序被执行。最后运行如下命令,就可以看到测试覆盖报告了。


coverage report -m
C:\python\unittest>coverage report -m
Name               Stmts   Miss  Cover  Missing
-------------------------------------------------
Calculator.py          17      0  100%
CalculatorTest.py      44     0   100%
-------------------------------------------------
TOTAL                  61      0  100%


3.3 unittest的断言


关于unittest的断言,参见表4所示。


4                                                                unittest的断言

断言方法

断言描述

assertEqual(a, b[, msg=None]) 

判断a==b,测试通过(用于数字)

assertNotEqual(a, b[, msg=None])

判断a!=b,测试通过

assertAlmostEqual(a, b[, places, ...])

判断a==b,测试通过(places为浮点数精度)

assertTrue(x[, msg=None])

bool(x) 为真,测试通过

assertFalse(x[, msg=None])

bool(x) 为假,测试通过

assertIs(a, b[, msg=None])

abl相同,测试通过

assertIsNot(a, b[, msg=None])

ab,测试通过

assertIsNone(x[, msg=None])

 x 是空,测试通过

assertIsNotNone(x[, msg=None])

x 不是空,测试通过

assertIn(a, b[, msg=None]) 

a 包含b,测试通过

assertNotIn(a, b[, msg=None])

a 不包含 b,测试通过

assertIsInstance(a, b[, msg=None])

ab的一个实例,测试通过

assertNotIsInstance(a,b[, msg=None]) 

a不是b的一个实例,测试通过

assertDictContainsSubset(a,b[,msg=none])

a字典中是否包含b

assertDictEqual(a, b[,msg=none])

两个字典是否相等

assertGreater(a, b[,msg=none])

a>b

assertGreaterEqual(a, b[,msg=none])

a>=b

assertItemsEqual(expected_seq,actual_seq[,msg=none])

一个无序的序列特异性的比较。

assertListEqual(list1,list2[,msg=none])

list1list2是否相等.

assertMultiLineEqual(first, second[,msg=none])

2个多行字符串是相等的

assertNotRegexpMatches(text,unexpected_regexp)

如果文本匹配正则表达式,将失败。

assertRaises(excClass[, callableObj])

除非excclass类抛出异常失败

assertRaisesRegexp(expected_exceptn, ...)

认为在引发异常的情况下消息匹配一个正则表达式。

assertRegexpMatches(text,expected_regexp[,msg=none])

测试失败,除非文本匹配正则表达式。

assertSequenceEqual(seq1,seq2[, msg,seq_type])

有序序列的相等断言 (like lists and tuples)


3.4 unittest批量运行及报告产生


JUnit一样,unittest也可以进行批量测试,并且可以在测试完毕形成一个HTML格式的测试报告。为了实现HTML格式的测试报告,可以先到http://tungwaiyip.info/software/HTMLTestRunner.html下载HTMLTestRunner.py文件放入到%PYTHON_HOME%\Lib\目录下。如果使用的是Python X系列就不需要进行修改,Python 3.X系列请作如下修改。


94行
import StringIO
改为
import io
539行
self.outputBuffer = StringIO.StringIO()
改为
self.outputBuffer = io.StringIO()
631行
print >>sys.stderr, '\nTime Elapsed:  %s' % (self.stopTime-self.startTime)
改为
print (sys.stderr, '\nTime Elapsed: %s' %  (self.stopTime-self.startTime))
642行
if not rmap.has_key(cls):
改为
if not cls in rmap:
766行
 uo =  o.decode('latin-1')
改为
uo = o
772行
ue = e.decode('latin-1')
改为
ue = e


下面是unittest批量运行及报告产生的代码。


案例7unittest批量运行及报告产生。


#!/usr/bin/env python
#coding:utf-8
import unittest
from HTMLTestRunner import HTMLTestRunner#导入HTMLTestRunner
test_dir='./'#测试的工作目录
discover=unittest.defaultTestLoader.discover(test_dir,pattern="*Test.py")#"*Test.py"为测试的文件,支持正则表达式
if __name__=='__main__':
    runner=unittest.TextTestRunner()#运行符合条件的测试文件
    #以下用于生成测试报告
    fp=open("result.html","wb")#result.html为测试报考名
    runner=HTMLTestRunner(stream=fp,title='测试报告',description='测试用例执行报告')
    runner.run(discover)
fp.close()


测试报告如图30所示。


image.png

30 unittest测试报告


星云测试

http://www.teststars.cc

奇林软件

http://www.kylinpet.com

联合通测

http://www.quicktesting.net


顾翔凡言:

k=(p+m)t

其中:

k为常数。

p:团队人员质量水平,为单位小时内产生的有效质量,单位为/h;

m:团队方法质量水平,为单位小时内产生的有效质量,单位为/h;

t:为单位质量产品的交付时间,单位为h。


在团队方法质量水平不变,团队人员质量水平提高的情况下,交付时间变短;

在团队人员质量水平不变,团队方法质量水平提高的情况下,交付时间变短;

团队人员质量水平与方法质量水平乘积决定了软件的质量水平,如果这个值变小,则t变大;反之t变小。


例如,当k=4时:

当人员质量水平为1/小时、方法水平为1/小时时,交付时间为2小时。

当人员质量水平为2/小时、方法水平为1/小时时,交付时间为4/3小时。

当人员质量水平为1/小时、方法水平为2/小时时,交付时间为4/3小时。

当人员质量水平为0.5/小时、方法水平为0.5/小时时,交付时间为4小时。

目录
相关文章
|
1月前
|
Java 测试技术 数据安全/隐私保护
软件测试中的自动化策略与工具应用
在软件开发的快速迭代中,自动化测试以其高效、稳定的特点成为了质量保证的重要手段。本文将深入探讨自动化测试的核心概念、常见工具的应用,以及如何设计有效的自动化测试策略,旨在为读者提供一套完整的自动化测试解决方案,帮助团队提升测试效率和软件质量。
|
1月前
|
Web App开发 IDE 测试技术
Selenium:强大的 Web 自动化测试工具
Selenium 是一款强大的 Web 自动化测试工具,包括 Selenium IDE、WebDriver 和 Grid 三大组件,支持多种编程语言和跨平台操作。它能有效提高测试效率,解决跨浏览器兼容性问题,进行性能测试和数据驱动测试,尽管存在学习曲线较陡、不稳定等缺点,但其优势明显,是自动化测试领域的首选工具。
180 17
Selenium:强大的 Web 自动化测试工具
|
2月前
|
机器学习/深度学习 人工智能 算法
BALROG:基准测试工具,用于评估 LLMs 和 VLMs 在复杂动态环境中的推理能力
BALROG 是一款用于评估大型语言模型(LLMs)和视觉语言模型(VLMs)在复杂动态环境中推理能力的基准测试工具。它通过一系列挑战性的游戏环境,如 NetHack,测试模型的规划、空间推理和探索能力。BALROG 提供了一个开放且细粒度的评估框架,推动了自主代理研究的进展。
48 3
BALROG:基准测试工具,用于评估 LLMs 和 VLMs 在复杂动态环境中的推理能力
|
2月前
|
监控 测试技术 开发工具
移动端性能测试工具
移动端性能测试工具
61 2
|
2月前
|
安全 前端开发 测试技术
如何选择合适的自动化安全测试工具
选择合适的自动化安全测试工具需考虑多个因素,包括项目需求、测试目标、系统类型和技术栈,工具的功能特性、市场评价、成本和许可,以及集成性、误报率、社区支持、易用性和安全性。综合评估这些因素,可确保所选工具满足项目需求和团队能力。
|
2月前
|
安全 网络协议 关系型数据库
最好用的17个渗透测试工具
渗透测试是安全人员为防止恶意黑客利用系统漏洞而进行的操作。本文介绍了17款业内常用的渗透测试工具,涵盖网络发现、无线评估、Web应用测试、SQL注入等多个领域,包括Nmap、Aircrack-ng、Burp Suite、OWASP ZAP等,既有免费开源工具,也有付费专业软件,适用于不同需求的安全专家。
260 2
|
2月前
|
监控 网络协议 Java
一些适合性能测试脚本编写和维护的工具
一些适合性能测试脚本编写和维护的工具
|
2月前
|
Web App开发 定位技术 iOS开发
Playwright 是一个强大的工具,用于在各种浏览器上测试应用,并模拟真实设备如手机和平板。通过配置 `playwright.devices`,可以轻松模拟不同设备的用户代理、屏幕尺寸、视口等特性。此外,Playwright 还支持模拟地理位置、区域设置、时区、权限(如通知)和配色方案,使测试更加全面和真实。例如,可以在配置文件中设置全局的区域设置和时区,然后在特定测试中进行覆盖。同时,还可以动态更改地理位置和媒体类型,以适应不同的测试需求。
Playwright 是一个强大的工具,用于在各种浏览器上测试应用,并模拟真实设备如手机和平板。通过配置 `playwright.devices`,可以轻松模拟不同设备的用户代理、屏幕尺寸、视口等特性。此外,Playwright 还支持模拟地理位置、区域设置、时区、权限(如通知)和配色方案,使测试更加全面和真实。例如,可以在配置文件中设置全局的区域设置和时区,然后在特定测试中进行覆盖。同时,还可以动态更改地理位置和媒体类型,以适应不同的测试需求。
133 1
|
3月前
|
Java 流计算
Flink-03 Flink Java 3分钟上手 Stream 给 Flink-02 DataStreamSource Socket写一个测试的工具!
Flink-03 Flink Java 3分钟上手 Stream 给 Flink-02 DataStreamSource Socket写一个测试的工具!
56 1
Flink-03 Flink Java 3分钟上手 Stream 给 Flink-02 DataStreamSource Socket写一个测试的工具!
|
3月前
|
jenkins 测试技术 持续交付
提升软件测试效率的实用技巧与工具
【10月更文挑战第12天】 本文将深入探讨如何通过优化测试流程、引入自动化工具和持续集成等策略,来显著提高软件测试的效率。我们将分享一些实用的技巧和工具,帮助测试人员更高效地发现和定位问题,确保软件质量。
79 2