Unit Testing

使用Mocha,Chai和Supertest对我们的Koajs工程的每个API进行单元测试。

模块准备

盖Koajs对ES6
generator的支持。所以在选模块的时节要选择相应的co封装模块。

  • mocha 和 co-mocha
  • chai
  • supertest 和 co-supertest

npm install mocha co-mocha supertest co-supertest chai --save-dev

至于 Mocha 和
Karma
的挑选此间就是不再讨论了 🙂

开班测试

co-mocha 引用

package.json中修改test script为:

"test": "mocha --harmony --require co-mocha"

要以测试文件被插:

require('co-mocha');

测试代码编写

创立测试文件solee.test.js.

第一在运作测试前用,写副一些必不可少之环境变量:

process.env.NODE_ENV = 'test';
process.env.DATABASE = 'mysql://********'

接下来引用我们的Koajs项目与对应模块。我们Koajs工程入口放在lib\index.js,并且注意co-supertest的援方式:

var app = require('../lib');
var request = require('co-supertest').agent(app.listen());
var should = require('chai').should();

describe叙我们需要测试的大约内容后,在it饱受初步写测试代码。因为见面动ES6的yield方因此function内需投入*

it('should return list of details with exist user', function *() {
    ···
}

利用co-supertest走访我们提供的api接口。可以一直调用内置expect夺举行有证过滤,例如:Content-Type是json,返回码是200相当于:

var res = yield request
        .get('/points/point/3/details')
        .set('Accept', 'application/json')
        .expect('Content-Type', /json/)
        .expect(200)
        .end();

拿到回内容res.text,再利用Chaishould模块对回到内容开展认证。

var body = JSON.parse(res.text);
      body.should.have.deep.property('data.list_points').length.above(0);
      body.should.have.deep.property('data.total_points').above(0);

最终运行npm test就可以看到对一个API简单单元测试的结果了。

测试结果

总结

咱得以对一个API进行各种状态的单元测试,但是以补偿我们没有想到的动静,可以助以测试的覆盖率来发现我们的意义是否完善。而覆盖率使用
istanbul
感觉爽爽的。

npm install -g istanbul

istanbul cover _mocha

_mocha前的下划线不克省。

题外话

自我开始写测试的早晚老是不成事,读取不交Koa工程app,最后发现是以下代码惹的危害:

http.createServer(app.callback()).listen(process.env.PORT || 3333);

修改成:

app.listen(process.env.PORT || 3333);

就OK了

相关文章

网站地图xml地图