1.pytest的六种退出代码
退出代码0: 收集并成功通过所有测试
退出代码1: 收集并运行测试但一些测试失败
退出代码2: 用户中断了测试执行
退出代码3: 执行测试时发生内部错误
退出代码4: pytest命令行使用错误
退出代码5: 没有收集任何测试
2.获取版本,选项名称,环境变量的帮助
pytest --version # 显示pytest的版本,和路径
pytest --fixtures # 显示可用的内置函数参数
pytest -h 或 pytest --help # 显示帮助文档
3.在第一次(或N次)失败后停止
pytest -x # 第一次失败后停止
pytest --maxfail=2 # 两次失败后停止
4.指定测试/选择测试
在模块中运行测试
pytest test_mod.py
在目录中运行测试
pytest testing/
按关键字表达式运行测试
pytest -k "MyClass and not method"
按节点ID运行测试
每个收集的测试都分配一个唯一的nodeid,包括模块文件名,后跟说明符,如类名,函数名和参数化参数,用::字符分隔。
在模块中运行特定测试:
pytest test_sample.py::test_answer # test_sample.py中的test_answer函数
pytest test_class.py::TestClass::test_one #test_class.py中的TestClass类中的test_one函数
通过标记表达式运行测试
pytest -m slow
@pytest.mark.slow # 被标记的测试用例被执行
def test_answer():
assert add(3, 1) == 5
从包中运行测试
pytest --pyargs pkg.testing
5.详细的总结报告
-r标志可用于在测试会话结束时显示测试结果摘要,从而可以在大型测试套件中轻松获得所有失败、跳过、标记失败(xfails)等测试结果的清晰图像
pytest -ra
-r选项接受后面的多个字符,上面使用的a表示“除了执行通过(Pass)以外所有的结果”。
以下是可以使用的可用字符的完整列表:
-f - 失败的用例
-E - 出错的用例
-s - 跳过的用例
-x - 标记失败的用例
-X - 标记成功的用例
-p - 成功用例
-P - 成功用例并输出信息
-a - 所有pP状态以外的用例
6.分析测试执行持续时间
pytest --durations=10
7.创建JUnitXML格式文件
pytest --junitxml=文件名
pytest --junitxml=report.xml
8.创建结果日志格式文件
9.加载插件
pytest -p mypluginmodule
10禁用插件
pytest -p no:doctestx`
11.在Python代码调用pytest
# -*- coding:utf-8 -*-
import pytest
# 求和方法
def add(x,y):
return x+y
@pytest.mark.slow
def test_answer():
assert add(3, 1) == 5
if __name__ == '__main__':
# pytest.main() # 执行当前所在文件夹及子目录下的所有测试用例
# pytest.main(['-x', 'test_sample.py']) # 通过参数,指定要运行的测试用例
pytest.main(['-x', 'test_class.py::TestClass::test_one']) # 通过参数,指定要运行的测试用例
在命令行执行该py文件
python2 test_sample.py
注意
调用pytest.main()将导致导入测试及其导入的任何模块。由于python导入系统的缓存机制,pytest.main()从同一进程进行后续调用不会反映调用之间对这些文件的更改。因此,pytest.main()不建议从同一进程进行多次调用(例如,为了重新运行测试)。