近几年,前端发展越来越迅猛,各类框架层出不穷,前端实现的业务逻辑也越来越复杂,前端单元测试也越来越受重视,包括百度在内的一些大厂在面试中也会问到单元测试相关的题目。那么前端应该如何做好单元测试?
来自维基百科的定义:
在计算机编程中, 单元测试(Unit Testing)又称为 模块测试,是针对程序模块(软件设计的最小单位)来进行正确性检验的测试工作。
程序单元是应用的最小可测试部件。在过程化编程中,一个单元就是单个程序、函数、过程等;对于面向对象编程,最小单元就是方法,包括基类(超类)、抽象类、或者派生类(子类)中的方法。
定义里面指出,单元测试针对的是程序的最小单元,因此我们应该针对最小单元来写单测。
单测完善程度的衡量用覆盖率来衡量
关于测试覆盖率,我们大致了解下以下几个常见的计算维度:
来看下面这个例子:
对于测试用例 foo(4),分支覆盖率只有50%,原因是 foo(4) 只测试了if 为 true 的情况,没有测试到 if 为 false 的情况。
如果想要分支覆盖率达到100%,还应该测试 foo(5)。
现在我也找了很多测试的朋友,做了一个分享技术的交流群,共享了很多我们收集的技术文档和视频教程。
如果你不想再体验自学时找不到资源,没人解答问题,坚持几天便放弃的感受
可以加入我们一起交流。而且还有很多在自动化,性能,安全,测试开发等等方面有一定建树的技术大牛
分享他们的经验,还会分享很多直播讲座和技术沙龙
可以免费学习!划重点!开源的!!!
qq群号:110685036【暗号:csdn999】
结果正确
这个是最基本的检查,如果单测的运行结果都不正确,那其他的都免谈。
边界条件检查
边界检查尤为重要,很多错误都是发生在边界上。边界检查遵循 CORRECT
反向关联检查
交叉检查
强制错误条件发生
满足性能要求
当某个程序升级的时候,是否会对性能造成影响?这需要我们对程序的性能进行测试
写单测的时机主要有以下三种,大家可以根据自己的实际情况来进行选择。
具体实现代码之前
即测试驱动开发(TDD):编写某个功能的代码之前先编写测试代码,然后编写使测试通过的功能代码,重复这个过程,通过测试来推动整个开发的进行。
特点:UT 能够更好的实践我们的代码设计。对于某些复杂度较高的接口(甚至是一些私有方法),建议使用 TDD 进行开发。
与具体实现代码同步进行
先写少量功能代码,紧接着写单元测试(重复这两个过程,直到完成功能代码开发)。
特点:每个单测比较简单易懂,可读性可维护性都比较好(重构时单测的改动不大)。
编写完功能代码后
这种单元测试“粒度”会比较粗。对同样的功能代码,采取前两种方案的结果可能是用10个“小”的单测来覆盖,而这种方案写的单测,往往是用1个“大”的单测来覆盖。
特点:逻辑就比较复杂,因为它要测的东西很多,可读性可维护性可能会比较差。
在我们开始选择单测工具之前,需要先了解测试工具的几种分类:
通常需要这几种类别的工具组合一起使用来完成测试,也有测试框架集成了这几类工具,如 Jest
,做到开箱即用。
Test runner
测试运行器,只负责找出代码中所有的单元测试用例,然后启动运行它们,最终获取测试结果。并不关心那些测试用例到底是用什么语言编写的,以及我们究竟采用的是什么框架,它所做的仅仅是运行这些测试而已。
Karma
是 Test runner
Test framework
测试框架,它定义了测试用例的语法和API,以及如何为这些用例编写断言。
Jasmine
Mocha
和Jest
是 Test framework
Testing Plugins
测试插件如Sinon
,使我们能够执行更多不同的测试,如mock、stubs、 fake servers等。
Assertion library
断言指的是一些布尔表达式,在程序中的某个特定点该表达式值为真,判断代码的实际执行结果与预期结果是否一致,而断言库则是讲常用的方法封装起来。
常用断言库主要有:
assert("mike" == user.name);
expect(foo).to.be("aa");
foo.should.be("aa");
以下介绍几种目前流行的测试工具供大家参考,主要有:
Jest是目前最流行的框架之一,是Facebook团队构建和维护的JavaScript测试框架,基于 Jasmine,至今已经做了大量修改添加了很多特性。
主要有以下优点:
Mocha是目前使用最多的js测试框架,同时支持前端和后端测试。可以在node.js和浏览器中运行,使异步测试变的简单而有趣。Mocha测试按串行运行,将未捕获的异常映射到正确的测试用例上,从而可以灵活、准确地报告。
主要优点包括:
但是mocha不提供断言,需要引入断言库,断言库可以选择 chai
sinon
Jasmine可以模仿用户行为,Jasmine可用于测试前端的可见性,单击清晰度以及不同分辨率下的UI响应速度。 Jasmine允许通过延迟和等待时间来自动化用户行为,以模拟实际的用户行为。
主要优点有:
AVA是一种极简的轻量级测试框架,它利用了Javascript的异步特性,可以并发运行测试。它主要专注于针对基于NodeJS的代码运行测试。
主要优点包括:
Tape 架构上与AVA非常相似,它不支持全局变量,因此需要在每个测试文件中require Tape。
主要优点为:
选择哪种测试框架不是非黑即白的,每种测试框架都有各自的优缺点,选择哪种框架可以根据项目实际情况及个人习惯来定。
个人更倾向于 Jest
,因为它容易上手,开箱即用,功能全面,官方文档很详细,对于新手来说使用成本很低。
END今天的分享就到此结束了!点赞关注不迷路~