测试的意义在于,在用户消费产出的代码以前,开发者首先消费它,给予其重要的质量保证。json
测试包括单元测试、性能测试、安全测试和功能测试等方面。安全
对于开发者而言,单元测试就是最基本的一种方式。若是开发者不本身测试代码,那必然要面对以下问题。服务器
编写可测试代码的原则:网络
对于开发者而言,不只要编写单元测试,还应当编写可测试代码。并发
单元测试主要包括断言、测试框架、测试用例、测试覆盖率、mock、持续集成等方面。因为Node的特殊性,还加入了异步代码测试和私有方法的测试 。框架
断言异步
断言:单元测试中用来保证最小单元是否正常的监测方法。性能
断言用于检查程序在运行时是否知足指望。单元测试
测试框架测试
记录下抛出的异常并继续执行,最后生成测试报告,这些任务的承担者就是测试框架。
测试框架用于测试服务,自己并不参与测试,主要用于管理测试用例和生成测试报告,提高测试用例的开发速度,提升测试用例的可维护性和可读性,以及一些周边性的工做。
测试风格
将测试用例的不一样组织方式称为测试风格。
主流的单元测试风格:
二者的差异:
测试报告
不管采用哪一个断言库,运行测试用例后,测试报告是开发者和质量管理者都关注的东西。
测试代码的文件组织
想让单元测试顺利运行起来,得在包描述文件(package.json)中添加相应模块的依赖关系。
测试用例
一个行为或者功能须要有完善的、多方面的测试用例,一个测试用例中包含至少一个断言。
测试用例最少须要经过正向测试和反向测试保证测试对功能的覆盖,这是最基本的测试用例。
异步测试
超时设置
若是一个测试用例的执行时间超过了预期时间,将会记录下一个超时时间,而后执行下一个测试用例。
测试覆盖率
经过不停地代码添加测试用例,将会不断地覆盖代码的分支和不一样的状况。
mock
mock:经过伪造被调用方法来测试上层代码的健壮性。
经过模拟底层方法出现异常的状况,只要监测调用方的输出值是否符合指望便可,无须关注是否真正的异常。
私有方法的测试
rewire模块提供了一种巧妙的方式实现对私有方法的访问。
工程化
Node中使用Makefile来构建工程。
持续集成
对于实际的项目,频繁地迭代是常态,如何记录版本的迭代信息,还须要一个持续集成的环境。
社区中流行的方式----利用travis实现持续集成。
性能测试的范畴较为普遍,包括负载测试、压力测试和基准测试。
基准测试要统计的是在多少时间内执行了多少次某个方法。
对网络接口进行压力测试以判断网络接口的性能。
对网络接口作压力测试须要考察的指标有:吞吐率、响应时间和并发数。这些指标反映了服务器的并发处理能力。
基准测试驱动开发(BDD):
其流程:
在进行实际的功能开发前,须要评估业务量,以便开发完成后可以胜任实际的在线业务量。