Istanbul代码覆盖率检测指南
时间:2025-10-02 09:24:48 340浏览 收藏
“纵有疾风来,人生不言弃”,这句话送给正在学习文章的朋友们,也希望在阅读本文《JS代码覆盖率工具:Istanbul检测指南》后,能够真的帮助到大家。我也会在后续的文章中,陆续更新文章相关的技术文章,有好的建议欢迎大家在评论留言,非常感谢!

JS 代码覆盖率检测,简单来说,就是看看你的测试用例到底测到了多少代码。Istanbul (现在通常叫 nyc) 是个很棒的工具,能帮你统计这个。
Istanbul 统计测试用例的覆盖范围
如何用 Istanbul (nyc) 检测代码覆盖率?
首先,你需要安装 nyc 和你用的测试框架,比如 Jest 或者 Mocha。 假设你用的是 Jest,那么:
npm install --save-dev nyc jest
然后,在你的 package.json 里面,改一下 test 命令:
{
"scripts": {
"test": "nyc jest"
}
}跑 npm test,就会自动生成覆盖率报告了。报告通常在 coverage 文件夹里,你可以打开 index.html 看看具体哪些代码没测到。
为什么我的覆盖率总是上不去?
覆盖率上不去,可能有很多原因。最常见的是,有些代码根本没被测试用例执行到。比如,一些错误处理的代码,只有在特定情况下才会触发。还有一些代码,可能是过时的,根本没用到了。
解决办法也很简单,就是仔细分析覆盖率报告,看看哪些代码没测到,然后针对性地写测试用例。如果发现有没用的代码,直接删掉就好。
如何忽略一些不需要覆盖率检测的文件或文件夹?
有些文件,比如配置文件、第三方库,或者一些工具脚本,可能不需要覆盖率检测。这个时候,你可以在 package.json 里配置 nyc,告诉它忽略这些文件。
{
"nyc": {
"exclude": [
"config/",
"node_modules/",
"scripts/"
]
}
}这样,nyc 在统计覆盖率的时候,就会忽略 config、node_modules 和 scripts 这三个文件夹里的文件了。
如何在 CI/CD 环境中生成覆盖率报告并上传?
在 CI/CD 环境中,通常需要生成覆盖率报告,并上传到代码托管平台,比如 GitHub 或者 GitLab。这样,每次提交代码的时候,就能自动检查覆盖率是否达标。
以 GitHub Actions 为例,你可以创建一个 coverage.yml 文件,内容如下:
name: Code Coverage
on:
push:
branches: [ main ]
pull_request:
branches: [ main ]
jobs:
coverage:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Use Node.js 16
uses: actions/setup-node@v3
with:
node-version: 16
- run: npm install
- run: npm test
- name: Upload coverage to Codecov
uses: codecov/codecov-action@v3
with:
token: ${{ secrets.CODECOV_TOKEN }}
flags: unittests
name: codecov-umbrella这个配置会监听 main 分支的 push 和 pull request 事件,然后自动运行测试,并把覆盖率报告上传到 Codecov。你需要先在 Codecov 上注册一个账号,然后把你的 Codecov token 配置到 GitHub Actions 的 secrets 里。
如何设置覆盖率阈值,防止代码质量下降?
为了防止代码质量下降,可以设置覆盖率阈值。比如,要求代码覆盖率必须达到 80% 以上。如果覆盖率低于这个阈值,就认为测试不通过。
在 package.json 里,你可以配置 nyc 的 check-coverage 选项:
{
"nyc": {
"check-coverage": true,
"statements": 80,
"branches": 80,
"functions": 80,
"lines": 80
}
}这样,每次运行测试的时候,nyc 都会检查代码覆盖率是否达到 80%。如果没有达到,就会报错。
如何在 TypeScript 项目中使用 Istanbul (nyc)?
在 TypeScript 项目中使用 Istanbul (nyc) 稍微麻烦一点,因为需要先将 TypeScript 代码编译成 JavaScript 代码,才能进行覆盖率检测。
首先,你需要安装 ts-node 和 @types/jest:
npm install --save-dev ts-node @types/jest
然后,修改你的 jest.config.js 文件,告诉 Jest 使用 ts-node 来处理 TypeScript 文件:
module.exports = {
preset: 'ts-jest',
testEnvironment: 'node',
};最后,修改你的 package.json 文件,告诉 nyc 如何运行测试:
{
"scripts": {
"test": "nyc --extension .ts jest"
}
}这样,nyc 就会自动编译 TypeScript 代码,并生成覆盖率报告了。
理论要掌握,实操不能落!以上关于《Istanbul代码覆盖率检测指南》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
274 收藏
-
232 收藏
-
339 收藏
-
359 收藏
-
342 收藏
-
385 收藏
-
192 收藏
-
360 收藏
-
149 收藏
-
477 收藏
-
313 收藏
-
169 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习