Project Icon

coverlet

跨平台.NET代码覆盖率工具,支持行、分支和方法覆盖

Coverlet是一款跨平台的.NET代码覆盖率工具,支持行、分支和方法覆盖分析。该工具兼容Windows上的.NET Framework和各支持平台上的.NET Core。Coverlet提供VSTest引擎集成、MSBuild任务集成和.NET全局工具三种使用方式,专为SDK风格项目设计。项目文档详尽,示例丰富,有助于开发者快速掌握使用方法。

Coverlet

构建状态 代码覆盖率 许可证: MIT

驱动程序当前版本下载量
coverlet.collectorNuGetNuGet
coverlet.msbuildNuGetNuGet
coverlet.consoleNuGetNuGet

Coverlet 是一个跨平台的 .NET 代码覆盖率框架,支持行覆盖、分支覆盖和方法覆盖。它可以在 Windows 上的 .NET Framework 和所有支持平台上的 .NET Core 中使用。

Coverlet 文档反映了功能的当前存储库状态,而不是已发布的版本。 请查看更新日志以了解您想使用的文档化功能是否已正式发布。

主要内容

快速入门

Coverlet 可以通过三种不同的驱动程序使用

  • VSTest 引擎集成
  • MSBuild 任务集成
  • 作为 .NET 全局工具(支持独立集成测试)

Coverlet 仅支持 SDK 风格的项目 https://docs.microsoft.com/en-us/visualstudio/msbuild/how-to-use-project-sdk?view=vs-2019

VSTest 集成(由于已知问题,推荐使用)

安装 (coverlet.collector)

dotnet add package coverlet.collector

注意:您必须仅将包添加到测试项目中。如果您创建 xunit 测试项目(dotnet new xunit),您会发现在 csproj 文件中已经存在引用,因为 Coverlet 是每个 .NET Core 和 >= .NET 6 应用程序的默认覆盖率工具,您只需在需要时更新到最新版本。请勿在测试项目中同时添加 coverlet.collectorcoverlet.msbuild 包。

使用方法 (coverlet.collector)

Coverlet 作为数据收集器集成到 Visual Studio 测试平台中。要获取覆盖率,只需运行以下命令:

dotnet test --collect:"XPlat Code Coverage"

运行上述命令后,一个包含结果的 coverage.cobertura.xml 文件将作为附件发布到 TestResults 目录中。

高级用法请参阅文档

要求 (coverlet.collector)

  • 您需要运行 .NET 6.0 SDK v6.0.316 或更新版本
  • 您需要引用 Microsoft.NET.Test.Sdk 的 17.5.0 及以上版本
<PackageReference Include="Microsoft.NET.Test.Sdk" Version="17.5.0" />

MSBuild 集成(可能受到已知问题的影响)

安装 (coverlet.msbuild)

dotnet add package coverlet.msbuild

注意:通常你必须只在测试项目中添加包。不要在测试项目中同时添加coverlet.msbuildcoverlet.collector包。

使用 (coverlet.msbuild)

Coverlet还集成了构建系统,可以在测试后运行代码覆盖率。启用代码覆盖率非常简单,只需将CollectCoverage属性设置为true即可

dotnet test /p:CollectCoverage=true

运行上述命令后,将在测试项目的根目录中生成一个包含结果的coverage.json文件。结果摘要也会显示在终端中。

高级用法请参阅文档

要求 (coverlet.msbuild)

需要支持_.NET Standard 2.0及以上版本_的运行时

.NET 全局工具(指南,可能存在已知问题

安装 (coverlet.console)

dotnet tool install --global coverlet.console

使用 (coverlet.console)

coverlet工具通过指定包含单元测试的程序集路径来调用。你还需要使用--target--targetargs选项分别指定测试运行器和传递给测试运行器的参数。使用提供的参数调用测试运行器不得涉及单元测试程序集的重新编译,否则将无法生成覆盖率结果。

以下示例展示了如何使用常见的dotnet test工具链:

coverlet /path/to/test-assembly.dll --target "dotnet" --targetargs "test /path/to/test-project --no-build"

注意:指定--no-build标志是为了确保不会重新构建/path/to/test-assembly.dll程序集

高级用法请参阅文档

要求 (coverlet.console)

.NET全局工具依赖于安装在你机器上的.NET Core运行时 https://docs.microsoft.com/zh-cn/dotnet/core/tools/global-tools#what-could-go-wrong

.NET Coverlet全局工具需要_.NET Core 2.2及以上版本_

工作原理

Coverlet通过以下过程生成代码覆盖率信息:

测试运行前

  • 定位单元测试程序集并选择所有具有PDB的引用程序集。
  • 通过插入代码来记录序列点命中到临时文件,从而对所选程序集进行插桩。

测试运行后

  • 恢复原始的未插桩程序集文件。
  • 从临时文件读取记录的命中信息。
  • 从命中信息生成覆盖率结果并将其写入文件。

确定性构建支持

Coverlet支持确定性构建的覆盖率。目前的解决方案并不理想,需要一个变通方法。 请查看文档

遇到某些功能的问题?查看示例

已知问题

很遗憾,我们有一些已知问题,请在这里查看

Cake 插件

如果你使用Cake Build作为构建脚本,可以使用Cake.Coverlet插件为dotnet test提供扩展,以强类型方式传递Coverlet参数。

Visual Studio 插件

如果你想在编码时在Visual Studio内部可视化Coverlet输出,可以根据你的平台使用以下插件。

Windows

如果你在Windows上使用Visual Studio,可以使用Fine Code Coverage扩展。 当你在Visual Studio内运行单元测试时,可视化会更新。

Mac OS

如果你使用Visual Studio for Mac,可以使用VSMac-CodeCoverage扩展。

使用每晚构建版本

我们为所有包提供master分支的每晚构建版本。 查看文档

问题与贡献

如果你发现bug或有功能请求,请在本仓库的issues部分报告。有关构建和贡献此项目的详细信息,请参阅贡献指南

Coverlet 团队

作者和所有者

共同维护者

行为准则

本项目采用了Contributor Covenant定义的行为准则,以明确我们社区中的预期行为。

有关更多信息,请参阅.NET Foundation行为准则

致谢

部分代码基于OpenCover团队的工作 https://github.com/OpenCover

许可证

本项目采用MIT许可证。有关更多信息,请参阅LICENSE文件。

.NET Foundation支持

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号