单元测试之pytest

本文详细介绍了如何使用pytest进行单元测试,包括命名规则、自动生成HTML测试报告,以及配合allure进行测试用例描述和数据读取。涵盖了skipping测试、运行方式、文件读取和Allure的配置与实践案例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前提:需要安装pytest和pytest-html(生成html测试报告)

安装pytest

安装pytest-html

一、命名规则

 Pytest单元测试中的类名和方法名必须是以test开头,执行中只能找到test开头的类和方法,比unittest更加严谨

二、Pytest生成自带的html测试报告

案例一:

pytest.main("模块.py")【运行指定模块下,运行所有test开头的类和测试用例】

 案例二:

运行指定模块指定类指定用例,冒号分割,并生成测试报告

 案例三:

直接执行pytest.main() 【自动查找当前目录下,以test开头的文件或者以test结尾的py文件】

 三、Pytest调用语句

-x出现一条测试用例失败就退出测试

pytst.main(['-x','--html=./report.html','t12est000.py'])

 -s:显示print内容

 跳过

使用@pytest.mark.skip()跳过该用例(函数)

 四、Pytest的运行方式

. 点号,表示用例通过
F 表示失败 Failure
E 表示用例中存在异常 Error

五、文件读取

1.读取csv文件

 2.读取xml文件

 

六、allure 

Allure是一款轻量级并且非常灵活的开源测试报告框架。 它支持绝大多数测试框架, 例如TestNG、Pytest、JUint等。它简单易用,易于集成。

1).首先配置allure的环境变量

2).验证allure是否配置成功

 3).最后安装allure

 pip install allure-pytest

Allure常用的几个特性 

@allure.feature # 用于描述被测试产品需求
@allure.story # 用于描述feature的用户场景,即测试需求
with allure.step(): # 用于描述测试步骤,将会输出到报告中
allure.attach # 用于向测试报告中输入一些附加的信息,通常是一些测试数据,截图等

1).@allure.feature    @allure.story

 报错:

报这个错误的话把PyCharm关掉重开再重新运行就好了

 2).with allure.step()  allure.attach()

 练习:

 单元测试:通过读取csv/xml数据并且结合使用allure展示测试报告,验证开发中的add()和reduct()操作
(在@allure.story分别实现相加减)

 csv:

 xml:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值