0

0

C# 代码覆盖率工具使用方法 C#如何使用coverlet生成测试覆盖率报告

畫卷琴夢

畫卷琴夢

发布时间:2026-02-04 09:15:09

|

872人浏览过

|

来源于php中文网

原创

coverlet 是一个 .NET 覆盖率收集工具,本身不生成 HTML 报告,仅输出 JSON 或 Cobertura XML 格式数据;需配合 reportgenerator 等工具转换为 HTML。

c# 代码覆盖率工具使用方法 c#如何使用coverlet生成测试覆盖率报告

coverlet 是什么,它能直接生成 HTML 报告吗

coverlet 本身不生成 HTML 报告,它只负责在测试运行时收集覆盖率数据(输出 .json.cobertura.xml 格式),后续需配合 reportgenerator工具转换为可视化报告。直接执行 dotnet test 加 coverlet 参数,若没配输出格式或没接下游工具,你会看到控制台里只有“0%”“12%”这类数字,但没有文件生成。

如何用 coverlet + reportgenerator 生成 HTML 报告

分两步:先用 coverlet 收集数据,再用 reportgenerator 渲染。推荐用 dotnet tool 方式安装,避免全局环境污染:

  • 安装 reportgeneratordotnet tool install -g dotnet-reportgenerator-globaltool
  • 在测试项目目录下运行:dotnet test /p:CollectCoverage=true /p:CoverletOutputFormat=opencover /p:CoverletOutput=./coverage/
  • 生成 HTML:reportgenerator "-reports:./coverage/coverage.opencover.xml" "-targetdir:./coverage/report" "-reporttypes:Html"

注意:CoverletOutputFormat=opencover 是 reportgenerator 兼容性最好的格式;CoverletOutput 路径末尾要带斜杠,否则可能写入失败;生成的报告入口是 ./coverage/report/index.html

常见报错和绕过方法

覆盖率达不到预期?多半是以下原因:

maven使用方法 中文WORD版
maven使用方法 中文WORD版

本文档主要讲述的是maven使用方法;Maven是基于项目对象模型的(pom),可以通过一小段描述信息来管理项目的构建,报告和文档的软件项目管理工具。Maven将你的注意力从昨夜基层转移到项目管理层。Maven项目已经能够知道 如何构建和捆绑代码,运行测试,生成文档并宿主项目网页。希望本文档会给有需要的朋友带来帮助;感兴趣的朋友可以过来看看

下载
  • System.ArgumentException: Unable to find project root:说明 coverlet 找不到 .csproj,确保在含测试项目的目录下执行 dotnet test,不要在解决方案根目录盲目运行
  • 覆盖率显示为 0%,但测试明明通过:检查是否用了 [ExcludeFromCodeCoverage] 特性,或是否测试项目引用了被测项目但未启用 InternalsVisibleTo(内部类/方法无法被覆盖)
  • HTML 报告里路径乱码或缺失源码:reportgenerator 默认不嵌入源码,加参数 -sourcedirs:../src/MyProject 显式指定源码路径(注意是相对路径,且需指向实际 .cs 文件所在目录)

CI 环境中怎么稳定跑覆盖率

GitHub Actions 或 Azure Pipelines 里容易因路径、权限或并行测试导致覆盖率中断:

  • 禁用并行测试:dotnet test --no-build /p:CollectCoverage=true /p:CoverletOutputFormat=cobertura /p:CoverletOutput=./coverage/ /p:DisableParallelization=true
  • 确保 coverlet.msbuild 包版本与 SDK 兼容(.NET 6+ 推荐用 coverlet.collector,而非旧版 coverlet.msbuild
  • Linux CI 上注意大小写敏感:CoverletOutput 路径里的大小写必须与实际目录一致,否则 reportgenerator 找不到输入文件

最常被忽略的是:coverlet 默认不覆盖 async void 方法、构造函数初始化表达式(C# 12 的 primary constructors)、以及 global using 引入的命名空间——这些地方即使有逻辑,也不会计入覆盖率统计。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

425

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

538

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

313

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

78

2025.09.10

pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1911

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2095

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

1096

2024.11.28

javascriptvoid(o)怎么解决
javascriptvoid(o)怎么解决

javascriptvoid(o)的解决办法:1、检查语法错误;2、确保正确的执行环境;3、检查其他代码的冲突;4、使用事件委托;5、使用其他绑定方式;6、检查外部资源等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

177

2023.11.23

全国统一发票查询平台入口合集
全国统一发票查询平台入口合集

本专题整合了全国统一发票查询入口地址合集,阅读专题下面的文章了解更多详细入口。

19

2026.02.03

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 8.4万人学习

Git 教程
Git 教程

共21课时 | 3.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号