目录大纲
前提:需要安装pytest和pytest-html(生成html测试报告)
pip install pytest 和 pip install pytest-html
注意事项
在新建项目时需要选择
1. 命名规则
Pytest单元测试中的类名和方法名必须是以test开头,执行中只能找到test开头的类和方法,比unittest更加严谨
Pytest: setup, setup_class和teardown, teardown_class函数(和unittest执行效果一样)
运行于测试方法的始末,即:运行一次测试函数会运行一次setup和teardown
运行于测试方法的始末,但是不管有多少测试函数都只执行一次setup_class和 teardown_class
类方法以test开头
类方法非test开头
类方法下的函数名以test开头
类方法下的函数名非test开头
2. Pytest生成自带的html测试报告
前提条件:需要下载pytest-html模块(python自带的生成测试报告模块)
pip install pytest-html
只需要加入参数即可:
pytest.main(["–html=./report.html"])
如果不安装 pytest-html
安装pytest-html以后
2.1 指定测试用例并生成测试报告
2.2 运行指定模块下,运行所有test开头的类和测试用例
pytest.main(["–html=./report.html",“模块.py”])
2.3 直接执行pytest.main() 【自动查找当前目录下,以test_开头的文件或者以_test结尾的py文件】
pytest.main([‘–html=./report.html’])
在同一目录下新建俩个相同的py文件并写入相同的代码
在任意一个py文件里调用,生成的测试报告如下
py文件非以test_开头的文件或者以_test结尾
在同级目录下新建一个非以test_开头的文件或者以_test结尾的py文件 test01.py
此时再次调用,你会发现test01中的代码并没有执行
3. pytest调用语句
pytst.main([’-x’,’–html=./report.html’,‘t12est000.py’])
-x:出现一条测试用例失败就退出测试
-v:丰富信息模式, 输出更详细的用例执行信息
-s:显示print内容
-q:简化结果信息,不会显示每个用例的文件名
使用@pytest.mark.skip()跳过该用例(函数)
4. pytest的运行方式
. 点号,表示用例通过
F 表示失败 Failure
E 表示用例中存在异常 Error