前提:需要安装pytest和pytest-html(生成html测试报告)
代码:pip install pytest 和 pip install pytest-html
命名规则
Pytest单元测试中的类名和方法名必须是以test开头,执行中只能找到test开头的类和方法,比unittest更加严谨
案例:

运行于测试方法的始末,即:运行一次测试函数会运行一次setup和teardown
运行于测试方法的始末,但是不管有多少测试函数都只执行一次setup_class和 teardown_class
二、Pytest生成自带的html测试报告
前提条件:需要下载pytest-html模块(python自带的生成测试报告模块)
代码:pip install pytest-html
2.1 方式一:
pytest.main("模块.py")【运行指定模块下,运行所有test开头的类和测试用例】
代码:pytest.main(["--html=./report.html","模块.py"])
pytest.main(["--html=../report1.html", "test_01.py"])
2.2 方式二:
运行指定模块指定类指定用例,冒号分割,并生成测试报告
代码:pytest.main([‘--html=./report.html’,‘模块.py::类::test_a_001'])
pytest.main(["--html=../report1.html", "test_01.py::TestPy01::testPy001"])
2.3 方式三(无效):
直接执行pytest.main() 【自动查找当前目录下,以test_开头的文件或者以_test结尾的py文件】
代码:pytest.main([‘--html=./report.html’])
2.4 方式四:
Pytest调用语句:
代码:pytst.main(['-x','--html=./report.html','t12est000.py'])
-x:出现一条测试用例失败就退出测试
-v:丰富信息模式, 输出更详细的用例执行信息
-s:显示print内容
-q:简化结果信息,不会显示每个用例的文件名
扩充(跳过):
使用@pytest.mark.skip()跳过该用例(函数)
代码:

三、Pytest的运行方式

四、文件读取
4.1 读取csv文件
先创建文件,然后读取

4.2 读取xml文件

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

验证allure是否配置成功

其次要安装allure
代码:pip install allure-pytest
allure-pytest是Pytest的一个插件,通过它我们可以生成Allure所需要的用于生成测试报告的数据
5.1 Allure常用的几个特性

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

Pytest和allure效果展示
