React自动化测试

先说说为什么要折腾自动化测试。现在前端项目动不动几十个页面,业务逻辑复杂得跟蜘蛛网似的。上次我改了个公共组件,结果导致三个页面崩了,测试妹子追着我骂了半个月。自从上了自动化测试,这种破事再没发生过。每次提交代码前跑一遍测试用例,心里踏实多了。

Jest+Testing Library这套组合拳是真香。Jest负责跑测试和断言,Testing Library专攻组件渲染和交互模拟。配置起来也简单,create-react-app创建的项目直接自带,不用折腾webpack那些破事。要是老项目,安装几个依赖就行:

写测试用例其实有套路可循。比如测试按钮点击后是否调了接口,可以这么搞:

异步操作测试经常让人抓狂。比如等接口返回后再检查页面显示,这时候就得用findBy方法:

自定义Hooks测试有个小技巧。用@testing-library/react-hooks这个包,测起来特别顺手:

项目大了测试运行慢怎么办?可以试试Jest的--watch模式,只跑改动的测试文件。要是还嫌慢,就用--coverage --watchAll=false只在CI环境跑全量测试。我们团队在GitHub Actions里配置了自动化流水线,每次push自动跑测试,失败了直接阻断合并。

测试覆盖率不是越高越好。有些团队非要追求95%以上,结果净测些没用的。重点应该放在核心业务逻辑和公共组件上,比如支付流程、表单校验这些关键路径。我见过有人连UI组件的margin都测,纯属浪费时间。

Mock技巧很重要。比如要模拟axios请求,可以这么搞:

遇到ReactRouter或Redux的组件测试,用Wrapper包一下就行:

最后给新人几个建议:别指望一次把测试全覆盖,先从核心功能开始;测试代码也要保持DRY原则,重复逻辑抽成helper;遇到诡异的时间问题就用jest.advanceTimersByTime()控制虚拟时钟。

自动化测试刚开始会觉得在浪费时间,等项目迭代两三版就知道它的好了。特别是半夜三点被报警短信吵醒的时候,你会感谢曾经认真写测试的自己。

相关推荐
destinying13 小时前
性能优化之实战指南:让你的 Vue 应⽤跑得飞起
前端·javascript·vue.js
徐小夕14 小时前
JitWord Office预览引擎:如何用Vue3+Node.js打造丝滑的PDF/Excel/PPT嵌入方案
前端·vue.js·github
晴殇i14 小时前
揭秘JavaScript中那些“不冒泡”的DOM事件
前端·javascript·面试
孟陬14 小时前
国外技术周刊 #1:Paul Graham 重新分享最受欢迎的文章《创作者的品味》、本周被划线最多 YouTube《如何在 19 分钟内学会 AI》、为何我不
java·前端·后端
BER_c14 小时前
前端权限校验最佳实践:一个健壮的柯里化工具函数
前端·javascript
兆子龙15 小时前
别再用 useState / data 管 Tabs 的 activeKey 了:和 URL 绑定才香
前端·架构
sudo_jin15 小时前
前端包管理器演进史:为什么 npm 之后,Yarn 和 pnpm 成了新宠?
前端·npm
叁两15 小时前
用opencode打造全自动公众号写作流水线,AI 代笔太香了!
前端·人工智能·agent
golang学习记16 小时前
GitLens 十大神技:彻底改变你在 VS Code 中的 Git 工作流
前端·后端·visual studio code
SuperEugene16 小时前
后台权限与菜单渲染:基于路由和后端返回的几种实现方式
前端·javascript·vue.js