单元测试 pytest 模块
目录
2.3 直接执行 pytest.main() 【自动查找当前目录下,以test_ 开头的文件或者以_test 结尾的py 文件】
前提:需要安装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
类方法以 test 开头
类方法非 test 开头
类方法下的函数名以 test 开头
类方法下的函数名非 test 开头
前提条件:需要下载pytest-html模块(python自带的生成测试报告模块)
pip install pytest-html
只需要加入参数即可:
pytest.main(["–html=./report.html"])
如果不安装 pytest-html
安装 pytest-html 以后
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中的代码并没有执行
pytest.main([’-x’,’–html=./report.html’,‘t12est000.py’])
-x:出现一条测试用例失败就退出测试
-v:丰富信息模式, 输出更详细的用例执行信息
-s:显示print内容
-q:简化结果信息,不会显示每个用例的文件名
使用@pytest.mark.skip()跳过该用例(函数)
. 点号,表示用例通过
F 表示失败 Failure
E 表示用例中存在异常 Error