首先我们要理解什么是单元测试,集成测试,系统测试,验收测试。这是根据开发的阶段命名的测试方法,其中单元测试是粒度最小的测试阶段。而自动化测试实际上就是通过脚本让计算机自动执行单元测试代码或者集成测试代码。
单元测试一般是白盒测试,测试是否符合设计。集成测试一般是白加黑测试,测试设计的同时也测试是否满足需求。系统测试粒度最大,一般是黑盒测试,测试系统是否符合
需求规格说明书
。验收测试和系统测试类似,但验收测试是由用户去操作的。
下面解释一下阶段性测试方案的区别和联系:
黑盒测试不考虑程序内部结构和逻辑结构,主要是用来测试系统的功能是否满足需求规格说明书。一般会有一个输入值,一个输入值,和期望值做比较。
白盒测试主要应用在单元测试阶段,主要是对代码级的测试,针对程序内部逻辑结构,测试手段有:语句覆盖、判定覆盖、条件覆盖、路径覆盖、条件组合覆盖。
集成测试主要用来测试模块与模块之间的接口,同时还要测试一些主要业务功能。
系统测试是在经过以上各阶段测试确认之后,把系统完整地模拟客户环境来进行的测试
然后我们还要了解什么是测试驱动开发
TDD
,领域驱动开发DDD
,行为驱动开发BDD
,验收测试驱动开发ATDD
。下面是简单的解释:
TDD:测试驱动开发是敏捷开发中的一项核心技术,也是一种设计方法论,
TDD
首先考虑使用需求(对象、功能、过程、接口等),主要是编写测试用例,而测试框架可以持续进行验证测试用例。大行其道的一些模式对TDD
的支持都非常不错,比如MVC
和MVP
等DDD:
DDD
实际上也是建立在领域模型基础之上,因为它关注的是Service
层的设计,着重于业务的实现,将分析和设计结合起来,不再使他们处于分裂的状态,这对于我们正确完整的实现客户的需求,以及建立一个具有业务伸缩性的模型尤其重要。BDD:实际上
BDD
可以看作是对TDD
的一种补充,让开发、测试、BA以及客户都能在这个基础上达成一致,比如JBehave
之类的BDD
框架。ATDD:通过单元测试用例来驱动功能代码的实现,团队需要定义出期望的质量标准和验收细则,以明确而且达成共识的验收测试计划(包含一系列测试场景)来驱动开发人员的
TDD
实践和测试人员的测试脚本开发。面向开发人员,强调如何实现系统以及如何检验。
下面就配合其他组件,简单说说
mocha
这个单元测试框架的基本使用,在项目中的具体用法在其他文章中有单独的教程。
为了能在命令行自动跑test目录下的测试代码,
npm test
配置为mocha test/
,建议测试文件命名格式为*.test.js
。-
我们有个
users
控制器写在src/controller/users.js
中,那么新建一个测试文件test/users.test.js
,写下面的内容:const assert = require('assert');
const {add, mul, cover} = require('../src/math');
should();
// 这是不集成 mocha.js
add(2, 3).should.to.equal(5);
expect(add(2, 3)).to.equal(5);
assert.equal(add(2, 3), 5);
// 集成 mocha.js
describe('#math', () => {
// Test add function
describe('add', () => {
// skip, only,
it('should return 130 when 8 + 122', () => {
add(8, 122).should.equal(130); // chai.expect style
// expect(add(8, 122), 130); // chai.expect style
// assert.equal(add(8, 122), 130); // chai.assert style
});
it('should return 5 when 4 + 1', () => {
expect(add(4, 1), 5);
});
it('should return 77 when 33 + 44', () => {
expect(add(33, 44), 77);
});
});
// Test mul function
describe('mul', () => {
it('should return 20 when 5 * 4', () => {
expect(mul(5, 4), 20);
});
});
});
```
-
使用
istanbul
测试代码覆盖率,在windows
中脚本配置写法应该为"cover": "istanbul cover node_modules/mocha/bin/_mocha test/"
。然后执行npm run cover
测试覆盖率。
rf
fd
相关教程: