pytest + allure
pytest简单概述
需要安装pytest和pytest-html(生成html测试报告)
pip install pytest 和 pip install pytest-html
命名规则
Pytest单元测试中的类名和方法名必须是以test开头,执行中只能找到test开头的类和方法,比unittest更加严谨
Pytest的setup, setup_class和teardown, teardown_class函数(和unittest执行效果一样)
运行于测试方法的始末,即:运行一次测试函数会运行一次setup和teardown
运行于测试方法的始末,但是不管有多少测试函数都只执行一次setup_class和 teardown_class
Pytest生成自带的html测试报告
直接执行pytest.main()
【自动查找当前目录下,以test_开头的文件或者以_test结尾的py文件】
pytest.main(“模块.py”)
【运行指定模块下,运行所有test开头的类和测试用例】
pip install pytest-html() :python自带的插件
pytest.main(["–html=./report.html",“test3.py”])
pytest调用语句
pytest.main([’-x’,’–html=./report.html’,‘t12est000.py’])
#-x出现一条测试用例失败就退出测试
-v: 丰富信息模式, 输出更详细的用例执行信息
-s:显示print内容
-q: 简化结果信息,不会显示每个用例的文件名
-x出现一条测试用例失败就退出测试
-v丰富信息模式, 输出更详细的用例执行信息
pytest.main(["-v","–html=./truth.html",“test1.py”])
-s 显示print内容
pytest.main(["-s","–html=./truth.html",“test1.py”])
-q 简化结果信息,不会显示每个用例的文件名
pytest.main(["-q","–html=./truth.html",“test1.py”])
运行方式
. 点号,表示用例通过
F 表示失败 Failure
E 表示用例中存在异常 Error
读取CSV文件数据
allure
Allure是一款轻量级并且非常灵活的开源测试报告框架。 它支持绝大多数测试框架, 例如TestNG、Pytest、JUint等。它简单易用,易于集成。
allure的几个常用特性
@allure.feature # 用于描述被测试产品需求
@allure.story # 用于描述feature的用户场景,即测试需求
with allure.step(): # 用于描述测试步骤,将会输出到报告中
allure.attach # 用于向测试报告中输入一些附加的信息,通常是一些测试数据,截图等