网站首页 > 技术文章 正文
对于逻辑复杂、迭代频繁的前端项目,进行单元测试很有必要。
这样可以节省大量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项目测试服务器
你 发表评论:
欢迎- 07-08记oracle日志挖掘实操&查询归档不正常增长情况(一)
- 07-08Oracle 伪列!这些隐藏用法你都知道吗?
- 07-08orcl数据库查询重复数据及删除重复数据方法
- 07-08重大故障!业务核心表被truncate删除,准备跑路……
- 07-08oracle数据恢复—oracle执行truncate命令误删除数据的数据恢复
- 07-08Oracle-rac 修改scanip(oracle 修改sequence cache)
- 07-08ORACLE RAC CDB和PDB切换(oracle数据库rac切换)
- 07-08Oracle rac haip作用(oracle rac的典型特征)
- 596℃几个Oracle空值处理函数 oracle处理null值的函数
- 589℃Oracle分析函数之Lag和Lead()使用
- 576℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 573℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 569℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 562℃【数据统计分析】详解Oracle分组函数之CUBE
- 549℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 542℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
-
- 记oracle日志挖掘实操&查询归档不正常增长情况(一)
- Oracle 伪列!这些隐藏用法你都知道吗?
- orcl数据库查询重复数据及删除重复数据方法
- 重大故障!业务核心表被truncate删除,准备跑路……
- oracle数据恢复—oracle执行truncate命令误删除数据的数据恢复
- Oracle-rac 修改scanip(oracle 修改sequence cache)
- ORACLE RAC CDB和PDB切换(oracle数据库rac切换)
- Oracle rac haip作用(oracle rac的典型特征)
- 新手小白怎么学UI设计 推荐学习路线是什么
- 超实用!0基础UI设计自学指南(0基础学ui设计好就业吗)
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- 前端懒加载 (49)
- 前端获取当前时间 (50)
- 前端接口 (50)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle 中文 (51)
- oracle的函数 (57)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)