前提:需要安装pytest和pytest-html(生成html测试报告)
pip install pytest 和 pip install pytest-html
命名规则:
Pytest单元测试中的类名和方法名必须是以test开头,执行中只能找到test开头的类和方法,比unittest更加严谨
运行于测试方法的始末,即
:
运行一次测试函数会运行一次
setup
和
teardown
运行于测试方法的始末
,
但是不管有多少测试函数都只执行一次
setup_class
和
teardown_class
pytest.main("模块.py")【运行指定模块下,运行所有test开头的类和测试用例】
前提条件:需要下载
pytest-html
模块
(python
自带的生成测试报告模块
)
pip install pytest-html
Pytest调用语句
pytst
.
main
([
'-x'
,
'--html=./report.html'
,
't12est000.py'
])
-x
出现一条测试用例失败就退出测试
-v:
丰富信息模式
,
输出更详细的用例执行信息
-s:
显示
print
内容
-q:
简化结果信息,不会显示每个用例的文件名
扩充:跳过
使用
@pytest.mark.skip()
跳过该用例
(函数)
![](https://i-blog.csdnimg.cn/blog_migrate/edd893dc2b93f93d29f14cc609bcfe84.png)
Pytest的运行
.
点号,表示用例通过
F
表示失败
Failure
E
表示用例中存在异常 Error
读取XML
![](https://i-blog.csdnimg.cn/blog_migrate/27fb50f6eefd67b6f20f7cc5e57a7fb7.png)
allure
ALLure的特征
@allure.feature # 用于描述被测试产品需求
@allure.story # 用于描述feature的用户场景,即测试需求
with allure.step(): # 用于描述测试步骤,将会输出到报告中
allure.attach # 用于向测试报告中输入一些附加的信息,通常是一些测试数据,截图等
@allure.feature # 用于描述被测试产品需求
@allure.feature # 用于描述被测试产品需求