pytest文档70-Hook钩子函数完整API总结​

前言

pytest 的钩子函数有很多,通过钩子函数的学习可以了解到pytest在执行用例的每个阶段做什么事情,也方便后续对pytest二次开发学习。
详细文档可以查看pytest官方文档https://docs.pytest.org/en/latest/reference.html#hooks

钩子函数总结

第一部分:setuptools

引导挂钩要求足够早注册的插件(内部和setuptools插件),可以使用的钩子

  • pytest_load_initial_conftests(early_config,parser,args): 在命令行选项解析之前实现初始conftest文件的加载。

  • pytest_cmdline_preparse(config,args): (不建议使用)在选项解析之前修改命令行参数。

  • pytest_cmdline_parse(pluginmanager,args): 返回一个初始化的配置对象,解析指定的args。

  • pytest_cmdline_main(config): 要求执行主命令行动作。默认实现将调用configure hooks和runtest_mainloop。

第二部分:初始化挂钩

初始化钩子需要插件和conftest.py文件

  • pytest_addoption(parser): 注册argparse样式的选项和ini样式的配置值,这些值在测试运行开始时被调用一次。

  • pytest_addhooks(pluginmanager): 在插件注册时调用,以允许通过调用来添加新的挂钩

  • pytest_configure(config): 许插件和conftest文件执行初始配置。

  • pytest_unconfigure(config): 在退出测试过程之前调用。

  • pytest_sessionstart(session): 在Session创建对象之后,执行收集并进入运行测试循环之前调用。

  • pytest_sessionfinish(session,exitstatus): 在整个测试运行完成后调用,就在将退出状态返回系统之前。

  • pytest_plugin_registered(plugin,manager):一个新的pytest插件已注册。

第三部分:collection 收集钩子

  • pytest_collection(session): 执行给定会话的收集协议。

  • pytest_collect_directory(path, parent): 在遍历目录以获取集合文件之前调用。

  • pytest_collect_file(path, parent) 为给定的路径创建一个收集器,如果不相关,则创建“无”。

  • pytest_pycollect_makemodule(path: py._path.local.LocalPath, parent)  返回给定路径的模块收集器或无。

  • pytest_pycollect_makeitem(collector: PyCollector, name: str, obj: object) 返回模块中Python对象的自定义项目/收集器,或者返回None。在第一个非无结果处停止

  • pytest_generate_tests(metafunc: Metafunc)  生成(多个)对测试函数的参数化调用。

  • pytest_make_parametrize_id(config: Config, val: object, argname: str) 返回val 将由@ pytest.mark.parametrize调用使用的给定用户友好的字符串表示形式,如果挂钩不知道,则返回None val。

  • pytest_collection_modifyitems(session: Session, config: Config, items: List[Item]) 在执行收集后调用。可能会就地过滤或重新排序项目。

  • pytest_collection_finish(session: Session)  在执行并修改收集后调用。

第四部分:测试运行(runtest)钩子

  • pytest_runtestloop(session: Session)  执行主运行测试循环(收集完成后)。

  • pytest_runtest_protocol(item: Item, nextitem: Optional[Item]) 对单个测试项目执行运行测试协议。

  • pytest_runtest_logstart(nodeid: str, location: Tuple[str, Optional[int], str]) 在运行单个项目的运行测试协议开始时调用。

  • pytest_runtest_logfinish(nodeid: str, location: Tuple[str, Optional[int], str])在为单个项目运行测试协议结束时调用。

  • pytest_runtest_setup(item: Item) 调用以执行测试项目的设置阶段。

  • pytest_runtest_call(item: Item) 调用以运行测试项目的测试(调用阶段)。

  • pytest_runtest_teardown(item: Item, nextitem: Optional[Item])  调用以执行测试项目的拆卸阶段。

  • pytest_runtest_makereport(item: Item, call: CallInfo[None]) 被称为为_pytest.reports.TestReport测试项目的每个设置,调用和拆卸运行测试阶段创建一个。

  • pytest_pyfunc_call(pyfuncitem: Function)  调用基础测试功能。

第五部分:Reporting 报告钩子

  • pytest_collectstart(collector: Collector)   收集器开始收集。

  • pytest_make_collect_report(collector: Collector)   执行collector.collect()并返回一个CollectReport。

  • pytest_itemcollected(item: Item)    我们刚刚收集了一个测试项目。

  • pytest_collectreport(report: CollectReport)  收集器完成收集。

  • pytest_deselected(items: Sequence[Item])   要求取消选择的测试项目,例如按关键字。

  • pytest_report_header(config: Config, startdir: py._path.local.LocalPath)  返回要显示为标题信息的字符串或字符串列表,以进行终端报告。

  • pytest_report_collectionfinish(config: Config, startdir: py._path.local.LocalPath, items: Sequence[Item]) 返回成功完成收集后将显示的字符串或字符串列表。

  • pytest_report_teststatus(report: Union[CollectReport, TestReport], config: Config) 返回结果类别,简写形式和详细词以进行状态报告。

  • pytest_terminal_summary(terminalreporter: TerminalReporter, exitstatus: ExitCode, config: Config) 在终端摘要报告中添加一个部分。

  • pytest_fixture_setup(fixturedef: FixtureDef[Any], request: SubRequest) 执行夹具设置执行。

  • pytest_fixture_post_finalizer(fixturedef: FixtureDef[Any], request: SubRequest)  在夹具拆除之后但在清除缓存之前调用,因此夹具结果fixturedef.cached_result仍然可用(不是 None)

  • pytest_warning_captured(warning_message: warnings.WarningMessage, when: Literal['config’, 'collect’, 'runtest’], item: Optional[Item], location: Optional[Tuple[str, int, str]])      (已弃用)处理内部pytest警告插件捕获的警告。

  • pytest_warning_recorded(warning_message: warnings.WarningMessage, when: Literal['config’, 'collect’, 'runtest’], nodeid: str, location: Optional[Tuple[str, int, str]]) 处理内部pytest警告插件捕获的警告。

  • pytest_runtest_logreport(report: TestReport)  处理项目的_pytest.reports.TestReport每个设置,调用和拆卸运行测试阶段产生的结果。

  • pytest_assertrepr_compare(config: Config, op: str, left: object, right: object)  返回失败断言表达式中的比较的说明。

  • pytest_assertion_pass(item: Item, lineno: int, orig: str, expl: str)  (实验性的)在断言通过时调用。

第六部分:调试/相互作用钩

很少有可以用于特殊报告或与异常交互的挂钩:

  • pytest_internalerror(excrepr: ExceptionRepr, excinfo: ExceptionInfo[BaseException])  要求内部错误。返回True以禁止对将INTERNALERROR消息直接打印到sys.stderr的回退处理。

  • pytest_keyboard_interrupt(excinfo: ExceptionInfo[Union[KeyboardInterrupt, Exit]]) 要求键盘中断。

  • pytest_exception_interact(node: Union[Item, Collector], call: CallInfo[Any], report: Union[CollectReport, TestReport]) 在引发可能可以交互处理的异常时调用。

  • pytest_enter_pdb(config: Config, pdb: pdb.Pdb) 调用了pdb.set_trace()。

详细文档可以查看pytest官方文档https://docs.pytest.org/en/latest/reference.html#hooks

2021年第六期《python接口自动化+测试开发》课程,1月9号开学(火热报名中!)
本期上课时间:1月9号-4月18号,每周六、周日晚上20:30-22:30

(0)

相关推荐

  • 这两个Python工具真香!修改代码不会影响运行

    你是否运行过for循环并希望在for循环内的代码中添加更多详细信息?你可能会决定不这样做,因为添加更多详细信息意味着需要停止代码并重新运行所有内容. 代码已经运行了几个小时,停止代码会让人不爽.如果可 ...

  • pytest文档34-Hooks函数改变用例执行顺序(pytest_collection_modifyitems)

    前言 有一些小伙伴一直想改变pytest用例的执行顺序,实际上我们在用例设计原则上用例就不要有依赖顺序. pytest默认执行用例是先根据项目下的文件夹名称按ascii码去收集的,module里面的用 ...

  • pytest文档35-Hooks函数之统计测试结果(pytest_terminal_summary)

    前言 用例执行完成后,我们希望能获取到执行的结果,这样方便我们快速统计用例的执行情况. 也可以把获取到的结果当成总结报告,发邮件的时候可以先统计测试结果,再加上html的报告. pytest_term ...

  • pytest文档54-Hooks函数terminal打印测试结果(pytest_report_teststatus)

    前言 使用命令行执行pytest用例的时候,会在 terminal 终端打印整个用例的测试结果: .代表通过的用例 F代表失败的用例 E代表异常的用例 如果我们不喜欢这种报告结果,可以通过 pytes ...

  • pytest文档69-Hook函数之参数化pytest_generate_tests

    前言 pytest 实现参数化有三种方式 pytest.fixture() 使用 fixture 传 params 参数实现参数化 @ pytest.mark.parametrize 允许在测试函数或 ...

  • pytest文档1-环境准备与入门

    前言 首先说下为什么要学pytest,在此之前相信大家已经掌握了python里面的unittest单元测试框架,那再学一个框架肯定是需要学习时间成本的. 刚开始我的内心是拒绝的,我想我用unittes ...

  • pytest文档2-用例运行规则

    用例设计原则 文件名以test_*.py文件和*_test.py 以test_开头的函数 以Test开头的类 以test_开头的方法 所有的包pakege必须要有__init__.py文件 help帮 ...

  • pytest文档3-pycharm运行pytest

    前言 上一篇pytest文档2-用例运行规则已经介绍了如何在cmd执行pytest用例,平常我们写代码在pycharm比较多 写完用例之后,需要调试看看,是不是能正常运行,如果每次跑去cmd执行,太麻 ...

  • pytest文档5-fixture之conftest.py

    前言 前面一篇讲到用例加setup和teardown可以实现在测试用例之前或之后加入一些操作,但这种是整个脚本全局生效的,如果我想实现以下场景: 用例1需要先登录,用例2不需要登录,用例3需要先登录. ...

  • pytest文档6-fixture之yield实现teardown

    前言 上一篇讲到fixture通过scope参数控制setup级别,既然有setup作为用例之前前的操作,用例执行完之后那肯定也有teardown操作. 这里用到fixture的teardown操作并 ...