Pytest:hooks钩子函数


Pytest的钩子函数可分为6类,分别是: 引导钩子,初始化钩子、用例收集钩子、用例执行钩子、报告钩子、调试钩子。

引导钩子(Session): 在整个测试会话(Session)的生命周期中,用于配置和管理测试执行的环境。这些钩子函数在测试会话启动和结束时执行,可用于设置全局的测试配置、初始化测试环境、清理测试数据等。

初始化钩子(Module): 在每个测试模块(Module)的生命周期中,用于准备测试环境和执行一些初始化操作。这些钩子函数在每个测试模块开始执行之前调用,可用于加载模块级别的测试数据、准备测试环境等。

用例收集钩子(Function和Class): 在收集测试用例时,用于自定义测试用例的收集行为。这些钩子函数在 Pytest 收集测试用例时调用,可以用于过滤测试用例、动态生成测试用例等。

用例执行钩子(Function和Class): 在执行测试用例时,用于控制测试用例的执行流程和行为。这些钩子函数在执行测试用例之前和之后调用,可以用于设置前置条件、后置条件、收集测试结果等。

报告钩子(Session): 在测试会话结束时,用于生成测试报告和记录测试结果。这些钩子函数在测试会话结束时调用,可以用于自定义测试报告的输出格式、记录额外的测试信息等。

调试钩子(Session): 在进行调试时,用于控制测试执行的行为和提供调试信息。这些钩子函数在测试会话期间,通过调试器进行调试时调用,可用于设置断点、输出调试信息等。

详细文档参考pytest官方文档:https://docs.pytest.org/en/latest/reference.html#hooks

Bootstrapping hooks 引导钩子

引导挂钩要求足够早注册的插件(内部和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。

Initialization hooks 初始化钩子

初始化钩子需要调用插件和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 hooks 测试用例收集钩子

● 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) 在执行并修改收集后调用。

Test running (runtest) hooks 测试运行钩子

● 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 hooks 测试报告钩子

● 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) (实验性的)在断言通过时调用。

Debugging/Interaction hooks 调试/交互钩子

用于特殊报告或与异常交互

● 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()。

  • 20
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
pytest钩子函数pytest内置的回调函数,用于在测试过程中自定义和修改测试的行为。其中pytest_configure和pytest_sessionfinish是pytest内置的钩子函数钩子函数的执行顺序可以通过一些方法进行调整,例如使用tryfirst和trylast装饰器来指定钩子函数的执行顺序。tryfirst装饰器表示钩子函数会尽可能早地执行,而trylast装饰器表示钩子函数会尽可能晚地执行。此外,还可以使用hookwrapper装饰器来在其他钩子函数之前执行。 在pytest中,钩子函数可以用来修改测试项、定制报告等。例如,可以通过编写pytest插件来修改pytest-html报告,实现自定义的报告格式。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [pytest合集(10)— Hook钩子函数](https://blog.csdn.net/panc_guizaijianchi/article/details/126701234)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [【pytestpytestHook函数详解](https://blog.csdn.net/u011035397/article/details/109546814)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

blues_C

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值