前提:需要安装
pytest
和
pytest-html(
生成
html
测试报告)
pip install pytest 和 pip install pytest-html
1:
命名规则
Pytest
单元测试中的类名和方法名必须是以
test
开头
,
执行中只能找到
test
开头的类和方法,比
unittest
更加严谨
2:Pytest
生成自带的
html
测试报告
前提条件:需要下载
pytest-html
模块
(python
自带的生成测试报告模块
)
pip install pytest-html
案例一
pytest.main("
模块
.py")
【运行指定模块下,运行所有
test
开头的类和测试用例】
pytest
.
main
([
"--html=./report.html"
,
"
模块
.py"
])
![](https://i-blog.csdnimg.cn/blog_migrate/2819f12862a650a380f48d04309c9ded.png)
案例二
运行指定模块指定类指定用例,冒号分割,并生成测试报告
pytest
.
main
([
‘
--
html
=.
/
report
.
html’
,
‘
模块
.
py
::
类
::
test_a_001
'])
运行指定模块指定类指定用例,冒号分割,并生成测试报告
案例三
直接执行
pytest.main()
【自动查找当前目录下,以
test
开头的文件或者以
test
结尾的
py
文件】(课堂练
习
_test
)
pytest
.
main
([
‘
--
html
=.
/
report
.
html’
])
Pytest
调用语句
pytst
.
main
([
'-x'
,
'--html=./report.html'
,
't12est000.py'
])
-x
出现一条测试用例失败就退出测试
-v:
丰富信息模式
,
输出更详细的用例执行信息
-s:
显示
print
内容
-q:
简化结果信息,不会显示每个用例的文件名
扩充:跳过
使用@pytest.mark.skip()跳过该用例(函数):
@pytest
.
mark
.
skip
()
def
test001
(
self
):
assert
2
==
2
3:Pytest
的运行方式
.
点号,表示用例通过
F
表示失败
Failure
E
表示用例中存在异常
Error
![](https://i-blog.csdnimg.cn/blog_migrate/58088e6cb3467788a0d9ace170fc155c.png)
4:文件读取
4.1:
读取
csv
文件
![](https://i-blog.csdnimg.cn/blog_migrate/22da0a837a233f4916bbf0bcb7fb689c.png)
4.2:读取xml文件
5:allure
Allure
是一款轻量级并且非常灵活的开源测试报告框架。 它支持绝大多数测试框架, 例如
TestNG
、
Pytest
、
JUint
等。它简单易用,易于集成。
首先配置
allure
的环境变量
验证
allure
是否配置成功
![](https://i-blog.csdnimg.cn/blog_migrate/3a6fa32b3ca642285c40688cc9b38a10.png)
其次要安装allure
pip install allure-pytest allure-pytest是Pytest的一个插件,通过它我们可以生成Allure所需要的用于生成测试报告的数据
5.1:Allure常用的几个特性
@allure.feature #
用于描述被测试产品需求
@allure.story #
用于描述
feature
的用户场景,即测试需求
with allure.step
():
#
用于描述测试步骤,将会输出到报告中
allure.attach #
用于向测试报告中输入一些附加的信息,通常是一些测试数据,截图等
5.1.1:allure.feature
@allure.feature # 用于描述被测试产品需求
5.1.2:allure.story
@allure.story #
用于描述
feature
的用户场景,即测试需求
案例:
安装allure:pip install allure-pytest
allure-pytest是 Pytest 的一个插件,通过它我们可以生成 Allure 所需要的用于生成测试报告的数据
实现用户登录功能,场景为登录成功和登录失败