pytest-testmon 使用教程

pytest-testmon 使用教程

pytest-testmonSelects tests affected by changed files. Executes the right tests first. Continuous test runner when used with pytest-watch.项目地址:https://gitcode.com/gh_mirrors/py/pytest-testmon

项目介绍

pytest-testmon 是一个 pytest 插件,它能够自动选择并重新执行那些受最近代码变更影响的测试。这对于动态语言如 Python 来说是一个挑战,但 pytest-testmon 通过收集和比较测试与代码之间的依赖关系,实现了这一功能。它通过内部使用 Coverage.py 来收集这些依赖关系,并在每次测试执行时更新其数据库,因此它独立于版本控制系统工作。

项目快速启动

安装

首先,你需要安装 pytest-testmon。你可以使用 pip 来安装:

pip install pytest-testmon

初始化

在第一次使用时,你需要构建依赖数据库并将其保存到 testmondata 文件中:

pytest --testmon

使用

在你修改了某些代码(这些代码需要有测试覆盖)后,只需运行以下命令,pytest-testmon 就会只运行那些受最近变更影响的测试:

pytest --testmon

应用案例和最佳实践

应用案例

假设你在一个大型项目中工作,每天都有大量的代码变更。使用 pytest-testmon 可以帮助你只运行那些真正需要测试的代码,从而节省大量的时间和资源。例如,在一个持续集成(CI)环境中,你可以配置 pytest-testmon 来确保每次提交都只运行相关的测试。

最佳实践

  1. 定期更新数据库:确保每次代码变更后都运行 pytest --testmon,以保持依赖数据库的最新状态。

  2. 结合 pytest-watch 使用:如果你想在每次文件保存时都运行测试,可以结合 pytest-watch 使用:

    pip install pytest-watch
    ptw --testmon
    
  3. 处理失败的测试:pytest-testmon 总是会重新执行上次失败的测试,确保这些测试在每次运行时都能得到验证。

典型生态项目

pytest-watch

pytest-watch 是一个与 pytest-testmon 结合使用的工具,它可以在你每次保存文件时自动运行 pytest。这样可以实现实时测试反馈,提高开发效率。

Coverage.py

Coverage.py 是一个用于测量 Python 代码覆盖率的工具,pytest-testmon 内部使用它来收集测试与代码之间的依赖关系。通过结合使用这两个工具,可以更全面地了解项目的测试覆盖情况。

通过以上步骤和建议,你可以有效地使用 pytest-testmon 来优化你的测试流程,提高开发效率。

pytest-testmonSelects tests affected by changed files. Executes the right tests first. Continuous test runner when used with pytest-watch.项目地址:https://gitcode.com/gh_mirrors/py/pytest-testmon

  • 17
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
pytest-testreport是一个pytest插件,用于生成测试报告。在使用pytest-testreport时,可以通过pytest.ini文件对其进行配置,下面是pytest-testreport中一些常用的配置项及其说明: ``` [pytest] addopts = --html=report.html --self-contained-html ``` - `addopts`: 添加命令行选项,这里的选项将会在pytest命令中自动添加。这里的`--html=report.html`表示将测试报告输出到report.html文件中,`--self-contained-html`表示将报告中的资源文件(如样式表和图片)嵌入到HTML文件中,方便分享和传播。 ``` [pytest] junit_family=xunit2 ``` - `junit_family`: 指定JUnit XML报告格式,可选值有`xunit1`和`xunit2`。`xunit2`是较新的格式,可以支持更多的测试结果类型,建议使用。 ``` [pytest] markers = smoke: Run the smoke tests regression: Run the regression tests ``` - `markers`: 标记用于标识测试用例的类型,可在命令行中使用-m选项来指定运行的测试用例类型。例如,`pytest -m "smoke"`将只运行标记为smoke的测试用例。在这里,我们定义了两个标记:`smoke`和`regression`,分别用于标识烟雾测试和回归测试。 ``` [pytest] testpaths = tests ``` - `testpaths`: 指定测试用例所在的目录。在这里,我们将测试用例放在`tests`目录中。 ``` [pytest] filterwarnings = ignore:.*U.*mode is deprecated:DeprecationWarning ``` - `filterwarnings`: 过滤警告信息,这里的设置表示忽略所有包含`U`的警告信息并将`DeprecationWarning`作为警告类型。这样可以减少不必要的警告信息对测试报告的影响。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

谢贝泰Neville

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

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

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

打赏作者

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

抵扣说明:

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

余额充值