目录
覆盖率测量通常用于衡量测试的有效性。Coverage可以显示测试正在执行代码的哪些部分,以及哪些部分没有被执行。
coverage作用:用于检查代码测试覆盖率的工具。
官方文档:Coverage.py — Coverage.py 6.6.0b1 documentation
安装
# 安装
$ pip install coverage
# 验证安装版本
$ coverage --version
Coverage.py, version 6.5.0 with C extension
Full documentation is at https://coverage.readthedocs.io
运行方式
命令行方式
# 搜集被测代码覆盖率信息,保存到 .coverage 文件中
$ coverage run 测试文件.py
# 生成覆盖率统计结果报告
$ coverage report
# 以HTML的形式生成覆盖率统计结果报告
$ coverage html
.py文件方式
命名为run.py文件,放置在项目根目录下,具体如下:
import coverage
import pytest
# 实例化对象
cov = coverage.coverage()
cov.start()
# 测试
pytest.main(["-v", "-s"])
# 结束分析
cov.stop()
# 结果保存
cov.save()
# 命令行模式展示结果,并展示未执行代码具体行数,用于测试结果查看使用
cov.report(show_missing=True)
# 生成HTML覆盖率结果报告
cov.html_report(directory="res_html")
运行方式:进入到run.py文件所在路径执行以下命令
# 运行.py文件
$ python run.py
测试结果各参数含义
终端report里测试结果各参数含义:
- Stmts :代码总行数
- Miss:未执行代码行数
- Cover:代码覆盖率
report HTML中测试结果各参数含义:
- statements :代码总行数,不包含空行和注释行
- missing:未执行代码行数
- coverage:代码覆盖率
pytest与coverage联合使用示例
目录结构如下:

本文详细介绍了如何使用Python的coverage模块和pytest进行代码覆盖率测试。内容包括coverage的安装、运行方式(命令行及.py文件方式)、测试结果参数含义以及pytest与coverage的联合使用示例。通过具体的代码示例,展示了如何收集覆盖率信息、生成报告,并解释了报告中的各项指标。此外,还提供了不同运行方式下终端输出的结果和HTML报告页面的展示。

1万+

被折叠的 条评论
为什么被折叠?



