需要安装
pytest
和
pytest-html(
生成
html
测试报告)
pip install pytest
和
pip install pytest-html
命名规则
Pytest
单元测试中的类名和方法名必须是以
test
开头
,
执行中只能找到
test
开头的类和方法,比
unittest更加严谨
unittest
:
Setup>> setupclass , teardown >> teardownclass
(课堂作业)
Pytest: setup, setup_class
和
teardown, teardown_class
函数
(
和
unittest
执行效果一样
)
运行于测试方法的始末,即
:
运行一次测试函数会运行一次
setup
和
teardown
运行于测试方法的始末
,
但是不管有多少测试函数都只执行一次
setup_class
和
teardown_class
Pytest
生成自带的
html
测试报告
前提条件:需要下载
pytest-html
模块
(python
自带的生成测试报告模块
)
pip install pytest-html
案例一
pytest.main("
模块
.py")
【运行指定模块下,运行所有
test
开头的类和测试用例】
pytest
.
main
([
"--html=./report.html"
,
"
模块
.py"
])
案例二
运行指定模块指定类指定用例,冒号分割,并生成测试报告
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
Pytest的运行方式
.
点号,表示用例通过
F
表示失败
Failure
E
表示用例中存在异常
Error
文件读取:读取
csv
文件
4.2:读取xml文件
allure
Allure
是一款轻量级并且非常灵活的开源测试报告框架。 它支持绝大多数测试框架, 例如
TestNG、
Pytest、
JUint
等。它简单易用,易于集成。
首先配置
allure
的环境变量
安装
allure
pip install allure-pytest
allure-pytest
是
Pytest
的一个插件,通过它我们可以生成
Allure
所需要的用于生成测试报告的数据
Allure
常用的几个特性
@allure.feature #
用于描述被测试产品需求
@allure.story #
用于描述
feature
的用户场景,即测试需求
with allure.step
():
#
用于描述测试步骤,将会输出到报告中
allure.attach #
用于向测试报告中输入一些附加的信息,通常是一些测试数据,截图等
allure.feature
@allure.feature #
用于描述被测试产品需求
allure.story
@allure.story #
用于描述
feature
的用户场景,即测试需求
案例:
实现用户登录功能,场景为登录成功和登录失败
pytest和allure效果展示
with allure.step()
用于描述测试步骤,将会输出到报告中
allure.attach、
用于向测试报告中输入一些附加的信息,通常是一些测试数据,截图等
案例
实现产品信息展示,车展中的各种车的品牌
Pytest和allure效果展示
单元测试:通过读取
csv/xml
数据并且结合使用
allure
展示测试报告,验证开发中的
add()
和
reduct()
操作
(在
@allure.story
分别实现相加减)
xml加减法
csv加减法