网站首页 > 技术文章 正文
对于逻辑复杂、迭代频繁的前端项目,进行单元测试很有必要。
这样可以节省大量E2E测试的时间,保证代码的可靠性,量化评估研发团队、测试团队的产出。
1. 选型
常见的前端单元测试框架,有Mocha、Jasmine、Jest。我的选型思路如下:
- Mocha不自带断言,需要结合其他断言库才可使用。Jasmine、Jest自带断言;
- Github上,Star数分别是:Mocha 20.4k,Jasmine 15.1k,Jest 34.7k;
- Jest由Facebook出品。
综上,选择Jest。
2. 覆盖率报告
先说重点:
- Jest自带HTML格式的覆盖率报告,没有必要再安装jest-html-reporter这种第三方库。
- 要生成HTML覆盖率报告,需要手动修改Jest配置文件。
先配置一下Jest。如果按照官网的教程,直接执行jest --init会报错。应该执行:
npx jest --init
选择需要覆盖率报告:
配置完成后,会生成一个jest.config.js文件。
执行npm test,还是没有覆盖率报告:
还得修改jest.config.js文件,将 collectCoverage设置为true,并解除注释:
// Indicates whether the coverage information should be collected while executing the test
collectCoverage: true,
再次执行npm test,控制台就会展示覆盖率情况了:
同时,Jest会生成一个coverage目录,其子目录lcov-report内的index.html就是HTML格式的覆盖率报告了:
3. 第三方覆盖率报告
如果想要使用jest-html-reporter这个第三方库生成覆盖率报告,也不要按它主页所说的进行配置。直接在package.json新增如下配置最方便:
"jest": {
"reporters": [
"default",
["./node_modules/jest-html-reporter", {
"pageTitle": "Test Report"
}]
]
}
jest-html-reporter生成的覆盖率报告如下:
对比一下,还是Jest原生的覆盖率报告信息更全、样式更美观。
4. 量化评估产出
看覆盖率报告即可:
- 覆盖率不够:测试团队需要补充测试用例;
- 通过率不是100%:研发团队需要修正bug,提高代码质量。
猜你喜欢
- 2025-05-22 一天涨 23k Star 的开源项目「GitHub 热点速览」
- 2025-05-22 如何选择VueJS的两个API Composition API或者Options API
- 2025-05-22 「评测」 声色——海贝 Crystal6 多单元动铁耳机
- 2025-05-22 常用的七种性能测试
- 2025-05-22 接口测试及其测试流程
- 2025-05-22 Java开发中的自动化测试框架:从零开始玩转测试工具
- 2025-05-22 别克君越1.5t机电单元维修
- 2025-05-22 前端代码Review,一次性掰扯明白!
- 2025-05-22 C++语言的单元测试与代码覆盖率
- 2024-09-22 vue入门:使用mockjs搭建vue项目测试服务器
你 发表评论:
欢迎- 05-23浅谈3种css技巧——两端对齐
- 05-23JSONP安全攻防技术
- 05-23html5学得好不好,看掌握多少标签
- 05-23Chrome 调试时行号错乱
- 05-23本文帮你在Unix上玩转C语言
- 05-23Go 中的安全编码 - 输入验证
- 05-2331个必备的python字符串方法,建议收藏
- 05-23Dynamics.js – 创建逼真的物理动画的 JS 库
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端react (48)
- 前端md5加密 (49)
- 前端路由 (55)
- 前端数组 (65)
- 前端定时器 (47)
- 前端接口 (46)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle约束 (46)
- oracle 中文 (51)
- oracle链接 (47)
- oracle的函数 (57)
- mac oracle (47)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)