pytest
准备工作(在cmd里):
1安装
pip install -U pytest
2验证安装
pytest --version # 会展示当前已安装版本
3其他的
显示可用的内置函数参数
pytest --fixtures
通过命令行查看帮助信息及配置文件选项
pytest --help
一、pytets框架中的约束
所有的单测文件名都需要满足test_.py格式或_ test.py格式。
在单测文件中,测试类以Test开头,并且不能带有 init 方法(注意:定义class时,需要以T开头,不然pytest是不会去运行该class的)
在单测类中,可以包含一个或多个test_开头的函数。
此时,在执行pytest命令时,会自动从当前目录及子目录中寻找符合上述约束的测试函数来执行。
断言必须使用assert
二、arrtest断言语句
- pytest中的assert是一种断言语句,用于检查测试结果是否符合预期。它用于在测试代码中判断某个条件是否为真,如果条件为假,则会抛出一个AssertionError异常,并且测试将被标记为失败。
import pytestdef test_a():print("--tast_a")assert 1def test_b():print("--test_b")assert 0def add(a, b):return a + bdef test_add():assert add(2, 3) == 5assert add(0, 0) == 0assert add(-1, 1) == 0if __name__ == '__main__':pytest.main("-s test_abc.py")
-
如果其中任何一个assert语句失败,测试将被标记为失败,并且会显示相应的错误消息。
最后用的是pytest的测试类主函数
命令行模式(编译器中的终端)
pytest 文件路径/测试文件名 例如:pytest ./test_abc.py
三、pytest中测试类主函数
在main()中传参就相当于输出了pytest -*
可以多个传参:
eg:
pytest.main(["-s", "-x"])
main() 函数如果不带任何参数,那么执行的效果跟我们在 cmd 直接运行 pytest 命令一样,默认运行的是当前目录及子目录的所有文件夹的测试用例。
-m=xxx: 运行打标签(装饰器:@pytest.mark.xx)的用例
-reruns=xxx:失败重新运行
-q: 安静模式, 不输出环境信息
-v: 丰富信息模式, 输出更详细的用例执行信息
-s: 显示程序中的print/logging输出
-k:可以使用and、not、or等逻辑运算符,区分:匹配范围(文件名、类名、函数名)
-x: 出现一条测试用例失败就退出测试。调试阶段非常有用
–resultlog=./log.txt 生成log
–junitxml=./log.xml 生成xml报告
1、 -s的作用
-
显示测试函数的打印和输出,默认情况下pytest会隐藏来保持测试报告的整洁性。但是,有时候我们需要查看测试函数中的打印输出,以便进行调试或查找问题。-s就是让他们显示在控制台上。
-
上面的代码测试结果中显示test_a、b的输出
0、 Pytest Exit Code 含义清单
测试结束后最后一行会出现with exit code *,其中含义:
- Exit code 0 所有用例执行完毕,全部通过
- Exit code 1 所有用例执行完毕,存在Failed的测试用例
- Exit code 2 用户中断了测试的执行
- Exit code 3 测试执行过程发生了内部错误
- Exit code 4 pytest 命令行使用错误
- Exit code 5 未采集到可用测试用例文件
2、-m的作用
3、-q的作用
只显示测试结果的总结,不输出环境信息
试了一下没看出区别下次学习的时候研究一下