立志成为一名优秀测试开发工程师(第七天)——unittest框架的学习
目录
unittest框架的学习
一、测试类的编写
创建相关测试类cal.py、CountTest.py
二、常见断言方法
使用unittest单元测试框架编写测试用例CountTest.py
注意:执行的时候光标一定要放在括号后面,鼠标右键运行
三、对测试环境的初始化和清除模块
四、创建测试套件
五、跳过测试和预期失败
六、测试报告的生成,使用HtmlTestRunner生成测试报告
1.安装HtmlTestRunner.py
2.基本使用方法
3.自定义报告样式
4.高级配置
5.注意事项
unittest框架的学习
unittest是python单元测试框架,是受到JUnit的启发,
与其他语言中的主流单元测试框架有着相似的风格。
其支持测试自动化,配置共享和关键代码测试。
支持将测试样例聚合到测试集中,并将测试与报告框架独立。
它不仅适用于单元测试,还在自动化测试领域占有一席之地。
借助它组织执行测试用例,使用它提供的丰富的断言方法
进行测试结果的比对,并结合HTMLTestRunner生成
测试报告完成整个自动化测试流程。
即:用代码测试代码
unittest是python内置的单元测试框架,不需要,直接导入使用即可 测试用例需要继承unittest.TestCase 属性该类的测试用例其实就是一个实例方法 该测试用例方法,就必须要使用test开头
一、测试类的编写
cal.py
和 CountTest.py
展示了如何使用 Python 的 unittest
框架进行单元测试。以下是对代码结构和功能的详细说明:
创建被测类cal.py
cal.py
定义了一个 count
类,包含基础的数学运算和随机选择功能:
class count:def __init__(self, a, b):self.a = aself.b = bdef add(self):return self.a + self.bdef Subtraction(self):return self.a - self.bdef func(self):return self.a - self.b > 10 # 简化为直接返回布尔值def func2(self):names = ['张三', '李四', '王五', '皮蛋']return random.choice(names)
二、常见断言方法
使用unittest单元测试框架编写测试用例CountTest.py
常见断言方法 assertEqual() assertNotEqual() assertTrue()
assertEqual 如果两个值相等则测试通过
assertNotEqual 如果两个值不相等则测试通过
assertTrue()表达式结果是True,返回True
import unittest
from Day.day07.calc import countclass CountTest(unittest.TestCase):#测试加法def test_add(self):#类的实例化 类名加上()c1=count(4,5)#调用方法r=c1.add()#测试的本质是实际结果和需求结果的就比较#断言self.assertEqual(r,11)#测试减法def test_sub(self):#类的实例化c2=count(6,3)#调用减法r=c2.Subtraction()#断言self.assertEqual(r,3)def test_func1(self):c1=count(20,1)r=c1.func()self.assertTrue(r,msg="测试不通过")def test_names(self):c3=count(4,5)r=c3.func2()new_names=['张三','李四','王五','皮蛋','翠花','王峰','李思','花花','草草']self.assertIn(r,new_names,msg="不存在")
if __name__=='__main__':CountTest.main()
注意:执行的时候光标一定要放在括号后面,鼠标右键运行
运行结果:
三、对测试环境的初始化和清除模块
TestFixture 对测试环境的初始化和清除模块
测试用例以来的测试数据准备活动就可以在环境的初始化完成
初始化的时候加了什么,清除的时候就删什么
注意这两个名字一定要写对
模块级别>类级别>用例级别
from Day.day07.calc import count
import unittestdef setUpModule():print("________这是setUpModule_________")
def tearDownModule():print("—————————这是tearDownModule—————————")class CountTest(unittest.TestCase):
#用例的执行顺序按照ASCII码表来进行@classmethoddef setUpClass(cls)->None:print("———————这是setUpClass—————————")#每一个用例执行之前都要执行用例的初始化,用例执行之后,都要执行用例的清除#用例级别的初始化def setUp(self) -> None:print("——----这是setUp-------————")def tearDown(self) -> None:print("---------这是tearDown---------")#类级别的清除@classmethoddef tearDownClass(cls) -> None:print("------这是tearDownClass--------")def test_names(self):c3=count(4,5)r=c3.func2()new_names=['张三','李四','王五','皮蛋','翠花','王峰','李思','花花','草草']print(new_names)self.assertIn(r,new_names,msg="不存在")def test_func(self):print("加油加油加油")def test_add(self):c2=count(2,8)r3=c2.add()self.assertEqual(r3,10)if __name__ =='__main__':CountTest.main()
四、创建测试套件
unittest提供了实现某紫于求的装饰器,在执行测试用例时每个装饰前面加@符号。@unittest.skip(feason):无条件的跳过装饰的测试,说明跳过测试的原因@unittest.skiplf(condition,reason):跳过装饰的测试,如果条件为真。@unittest.skipUnless(condition,reason):跳过装饰的测试,除非条件为真。@unittest.expectedFailure():测试标记为失败,不管执行结果是否失败,统一标记为失败,但不会抛出错误信息。@unittest.expectedFailure #如果断言失败,不计入执行case数目中
方法1.通过addTest()加载TestCase到TestSuite中,用于少量的测试用例
#方法1.通过addTest()加载TestCase到TestSuite中,用于少量的测试用例
#创建测试套件
suite=unittest.TestSuite()
#给测试套件添加测试用例
#测试类类名+用例名字
suite.addTest(CountTest('test_add'))
suite.addTest(CountTest('test_names'))#执行测试套件 TextTestRunner
#创建执行器
runner=unittest.TextTestRunner()
#使用上面那个创建的执行器,执行测试套件
runner.run(suite)
#执行用例之后显示一个'.'代表通过一个测试用例
执行用例之后显示一个'.'代表通过一个测试用例
方法2:同时添加多个测试用例进入到套件之中
#addTests可以接受一个列表
suite=unittest.TestSuite()
cases=[CountTest('test_names'),CountTest('test_add')]
suite.addTests(cases)#生成执行器
runner=unittest.TextTestRunner()
runner.run(suite)
方法3:添加整个类的测试用例到套件中
suite=unittest.TestSuite()
suite.addTests(unittest.TestLoader().loadTestsFromTestCase(CountTest))
#创建执行器
runner=unittest.TextTestRunner()
runner.run(suite)
方法四 模糊匹配 给套件指定需要执行的测试用例
#制定匹配规则,会自动生成测试套件,将用例添加进去
#加载路径
test_dir='../day07'
#名字不用写完,后面加上*
discover=unittest.defaultTestLoader.discover(start_dir=test_dir,pattern='Cou*.py')
#创建执行器
runner =unittest.TextTestRunner()# #执行测试用例
runner.run(discover)
五、跳过测试和预期失败
对原有代码进行修改,加上相应注释,如下:
未显示“加油加油”这条用例内容,说明成功跳过,再做修改:
结果同上
结果同上
六、测试报告的生成,使用HtmlTestRunner生成测试报告
HtmlTestRunner是一个用于生成HTML格式测试报告的工具,可以方便地将unittest测试结果可视化。以下是如何使用HtmlTestRunner生成测试报告的方法。
借助HtmlTestRunner来生成,下载下来是一个.py文件
方式一、将下载的文件保存到...\python\lib目录下,不推荐
方式二、创建一个包,将py文件放进去就行了
1.安装HtmlTestRunner.py
通过网盘分享的文件:HTMLTestRunner.py
链接: https://pan.baidu.com/s/137-UO-ZDesn_bO_2c1NhGA 提取码: pz5q
2.基本使用方法
以下是一个完整的示例代码,展示了如何生成测试报告:
import os
import unittest
from common.HTMLTestRunner import HTMLTestRunner
import timereport_path = './report'# 测试报告的标题
report_title = '冒烟测试'# 测试的描述
report_desc = "对加减法功能的测试"# 创建报告目录
if not os.path.exists(report_path):os.mkdir(report_path)# 构建时间戳作为报告文件名
rtime = time.strftime("%Y%m%d%H%M%S")
filepath = os.path.join(report_path, f'report{rtime}.html')# 发现测试用例
case_path = '../day07'
suite = unittest.defaultTestLoader.discover(start_dir=case_path, pattern="C*.py")# 使用HTMLTestRunner运行测试并生成报告
with open(filepath, "wb") as f1:runner = HTMLTestRunner(stream=f1,title=report_title,description=report_desc)runner.run(suite) # 这里要使用HTMLTestRunner的run方法,不是TextTestRunner
生成后能在我们提前建好的包中找到:
点击即可选择浏览器打开:
3.自定义报告样式
HtmlTestRunner允许自定义报告的样式和内容:
runner = HTMLTestRunner(output=report_path,report_name='custom_report',add_timestamp=False,combine_reports=True
)
4.高级配置
可以在测试用例中添加更多信息来丰富报告内容:
class TestMath(unittest.TestCase):"""测试数学运算"""def test_addition(self):"""测试加法"""self.assertEqual(1 + 1, 2)def test_subtraction(self):"""测试减法"""self.assertEqual(3 - 1, 2)
5.注意事项
- 确保测试用例的命名规范一致,便于discover方法查找
- 报告路径需要有写入权限
- 时间戳可以避免报告文件被覆盖
- 测试用例中的docstring会显示在报告中
这种方法生成的HTML报告包含测试结果统计、详细测试步骤和错误信息,方便团队查看和分析测试结果。
相关文章:

立志成为一名优秀测试开发工程师(第七天)——unittest框架的学习
目录 unittest框架的学习 一、测试类的编写 创建相关测试类cal.py、CountTest.py 二、常见断言方法 使用unittest单元测试框架编写测试用例CountTest.py 注意:执行的时候光标一定要放在括号后面,鼠标右键运行 三、对测试环境的初始化和清除模块…...
精益数据分析(85/126):营收阶段的核心指标与盈利模型优化——从数据到商业决策的落地
精益数据分析(85/126):营收阶段的核心指标与盈利模型优化——从数据到商业决策的落地 c。 一、营收健康度的核心指标:投资回报率模型 (一)季度再发性营收增长率(QRR) 该指标衡量…...

论坛系统(4)
用户详情 获取用户信息 实现逻辑 ⽤⼾提交请求,服务器根据是否传⼊Id参数决定返回哪个⽤⼾的详情 1. 不传⽤⼾Id,返回当前登录⽤⼾的详情(从session获取) 2. 传⼊⽤⼾Id,返回指定Id的⽤⼾详情(根据用户id去查) 俩种方式获得用户信息 参…...
本地Markdown开源知识库选型指南
本地Markdown开源知识库选型指南 以下是几款优秀的本地Markdown开源知识库解决方案,适合不同需求场景: 1. Obsidian (非完全开源但免费) 特点:基于Markdown的本地优先知识管理,丰富的插件生态优势:双向链接、图形视…...
【.net core】SkiaSharp 如何在Linux上实现
1. 安装依赖库 首先需要安装 SkiaSharp 运行时依赖: # Ubuntu/Debian sudo apt-get update sudo apt-get install -y libfontconfig1 libfreetype6 libx11-6 libx11-xcb1 libxcb1 \libxcomposite1 libxcursor1 libxdamage1 libxi6 libxtst6 \libnss3 libcups2 lib…...
后端项目中静态文案国际化语言包构建选型
这是一个很关键的问题。在做国际化(i18n)时,不同语言包格式如 .resx、.properties 和 .json 都可用,但各自有适用场景、特性与限制,你在选择时可以根据你的开发语言、生态和维护成本权衡。 ✅ 一张对比表:.…...
前端面经 React常见的生命周期
初始化阶段 constructor state的初始化,防抖节流的绑定getDerivedStateFromProps 静态函数 当作纯函数使用 传入props和state,合并成一个新的statecomponentWillMount 组件如果有getDrivedStatefromprops不会执行 针对一些接口的预请求时使用rendercomp…...

力扣面试150题--二叉树的层平均值
Day 54 题目描述 思路 初次做法(笨):使用两个队列,一个队列存放树的节点,一个队列存放对应节点的高度,使用x存放上一个节点,highb存放上一个节点的高度,sum存放当前层的节点值之和…...

【Doris入门】Doris初识:分布式分析型数据库的核心价值与架构解析
目录 1 Doris简介与核心价值 2 Doris架构深度解析 2.1 Frontend(FE)架构 2.2 Backend(BE)架构 3 Doris核心概念详解 3.1 数据分布模型 3.2 Tablet与Replica 3.3 数据模型 4 Doris关键技术解析 4.1 存储引擎 4.2 查询执…...
C#面试问题41-60
41. What is the Singleton design pattern? Singleton is a class that only allows creating a single instance of itselt. 单例设计模式是一个类,它只允许创建自己的单个实例。 构造函数防止他在单例类以外的地方被调用。 使用情景:need a sing…...

数据结构与算法学习笔记(Acwing 提高课)----动态规划·区间DP
数据结构与算法学习笔记----动态规划区间DP author: 明月清了个风 first publish time: 2025.5.26 ps⭐️区间DP的特征在于子结构一般是一个子区间上的问题,涉及到的问题也非常多,如环形区间,记录方案数,高精度,二维…...
【合集】Linux——31个普通信号
Linux普通信号总表(1-31) 编号信号名触发原因默认动作1SIGHUP终端连接断开(如SSH会话终止)或守护进程重载配置(如nginx -s reload)终止进程2SIGINT用户输入CtrlC中断前台进程终止进程…...

从0到1搭建AI绘画模型:Stable Diffusion微调全流程避坑指南
从0到1搭建AI绘画模型:Stable Diffusion微调全流程避坑指南 系统化学习人工智能网站(收藏):https://www.captainbed.cn/flu 文章目录 从0到1搭建AI绘画模型:Stable Diffusion微调全流程避坑指南摘要引言一、数据集构…...
ASP.NET Core 中JWT的基本使用
文章目录 前言一、JWT与RBAC二、JWT 的作用三、RBAC 的核心思想四、使用1、配置文件 (appsettings.json)2、JWT配置模型 (Entity/JwtSettings.cs)3、服务扩展类,JWT配置 (Extensions/ServiceExtensions.cs)4、用户仓库接口服务5、认证服务 (Interface/IAuthService.…...
未来技术展望
应用场景:海量数据并行处理 技术融合: # 概念代码:量子加速的数据清洗 from quantum_processor import PhotonicProcessordef quantum_data_cleaning(data):# 使用光量子处理器并行处理千万级数据processor = PhotonicProcessor(model="Xanadu Borealis")return …...

从一到无穷大 #46:探讨时序数据库Deduplicate与Compaction的设计权衡
本作品采用知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议进行许可。 本作品 (李兆龙 博文, 由 李兆龙 创作),由 李兆龙 确认,转载请注明版权。 文章目录 引言Compaction AlgorithmsCompact Execution Flow Based On VeloxLocalMergeSource的…...

vue3 导出excel
需求:导出自带格式的excel表格 1.自定义二维数组格式 导出 全部代码: <el-button click"exportExcel">导出</el-button> const exportExcel () > {const data [[商品, 单价, 数量, 总价],[A, 100, 1.55, { t: n, f: B2*C2…...
带你手写React中的useReducer函数。(底层实现)
文章目录 前言一、为什么需要 Reducer?二、Reducer 的核心概念1. Reducer 函数2. useReducer 钩子 三,手写react中的useReducer 总结 前言 在 React 开发中,useReducer 是管理复杂状态逻辑的利器。它类似于 Redux 的简化版,允许我…...

day024-网络基础-TCP与UDP、DNS
文章目录 1. 李导推荐书籍2. OSI七层模型2.1 传输层2.2 网络层2.2.1 问:两端处于不同局域网的设备怎么网络通信? 2.3 数据链路层2.4 物理层2.5 图解OSI七层模型 3. 数据传输模式3.1 全双工3.2 半双工3.3 单工 4. TCP 3次握手4.1 抓包 5. TCP 4次挥手5.1 …...

专场回顾 | 重新定义交互,智能硬件的未来设计
自2022年起,中国智能硬件行业呈现出蓬勃发展的态势,市场规模不断扩大。一个多月前,“小智AI”在短视频平台的爆火将智能硬件带向了大众视野,也意味着智能硬件已不再仅仅停留在概念和技术层面,而是加速迈向实际落地应用…...
如何把一台电脑作为另外一台电脑的显示器
https://zhuanlan.zhihu.com/p/703889583 1. 两台电脑都要进行:点开投影到此电脑,点击可选功能,在可选功能窗口,搜索无线显示器;在结果列表中选中无线显示器,并安装 2. 在笔记本电脑(要用来做…...

WPS 免登录解锁编辑
遇到 WPS 需要登录才能启用编辑功能? 如何免登录使用编辑功能? 方法一 解锁方法 1、关闭 WPS; 2、桌面右键→ “新建”→“文本文档”,粘贴以下内容(见最下面);编码保持默认(ANSI …...
【C/C++】线程安全初始化:std::call_once详解
std::call_once 使用详解 std::call_once 是 C11 标准库中提供的一个线程安全的一次性调用机制,位于 <mutex> 头文件中。它确保某个可调用对象只被执行一次,即使多个线程同时尝试调用它。 基本用法 #include <mutex> #include <thread…...

技术分享 | Oracle SQL优化案例一则
本文为墨天轮数据库管理服务团队第70期技术分享,内容原创,作者为技术顾问马奕璇,如需转载请联系小墨(VX:modb666)并注明来源。 一、问题概述 开发人员反映有条跑批语句在测试环境执行了很久都没结束&…...
什么是RFID电子标签
RFID 电子标签是用于物品标识、具有信息存储机制、能接收读写器的电磁场调制信号并返回响应信号的数据载体,通常被称为电子标签,也可称作射频卡、射频标签、射频卷标等,是与读写器一起构成 RFID 系统的硬件主体。 RFID 系统基本组成包括RFID电子标签、读写器、射频天线、应用…...

华为手机用的时间长了,提示手机电池性能下降,需要去换电池吗?平时要怎么用能让电池寿命长久一些?
华为手机提示电池性能下降时,是否需要更换电池以及如何延长电池寿命,取决于电池老化程度和使用习惯。以下是具体分析和建议: 一、是否需要更换电池? 电池健康度低于80% 如果手机提示“电池性能下降”,通常意味着电池…...

BERT***
1.预训练(Pre-training) 是深度学习中的一种训练策略,指在大规模无标注数据上预先训练模型,使其学习通用的特征表示,再通过微调(Fine-tuning) 适配到具体任务 2.sentence-lev…...

超级对话2:大跨界且大综合的学问融智学应用场景述评(不同第三方的回应)之二
摘要:《人机协同文明升维行动框架》提出以HIAICI/W公式推动认知革命,构建三大落地场景:1)低成本认知增强神经接口实现300%学习效率提升;2)全球学科活动化闪电战快速转化知识体系;3)人…...
在Linux环境里面,Python调用C#写的动态库,如何实现?
在Linux环境中,Python可以通过pythonnet(CLR的Python绑定)或subprocess调用C#动态库。以下是两种方法的示例: 方法1:使用pythonnet(推荐) 前提条件 安装Mono或.NET Core运行时安装pythonnet包…...
【Linux 基础知识系列】第三篇-Linux 基本命令
在数字化浪潮席卷全球的当下,操作系统作为计算机系统的核心组件,扮演着至关重要的角色。而 Linux,凭借其卓越的性能、高度的稳定性和出色的可定制性,在服务器、嵌入式系统、超级计算机以及个人计算机等领域大放异彩,成…...