Mocha简介:

一个具有丰富特性的javascript 测试框架,支持多种断言库,异步代码测试等,不仅可运行在node.js 环境中还可以运行在浏览器中。

一、安装

// 全局安装
npm install -global mocha
// 在项目中安装
npm install --save-dev mocha

二、写一个简单的测试

2.1 首先新建一个项目,src 下待测试代码,test 下写测试用例。目录如下
//mocha-to-go
|   package.json
|   
+---node_modules
|           
+---src
|       sum.js
|       
\---test
        sum.test.js
        
2.2 待测试文件 sum.js
// 求函数所有参数的和
module.exports = sum = function () {
  let args = Array.from(arguments);
  let sum = 0;
  sum = args.reduce((s, x) => {
    return s +=x
  });
  return sum;
}
2.3 新建测试脚本

mocha 支持多种断言库,比如should.js 、expect.js 、chai.js 等,这里以chai.js 为例。选择chai.js 的Expect风格的断言,它是行为驱动开发(BDD)断言的一种,接近于自然语言,容易理解。可运行在所有的浏览器中和node.js中

先安装断言库chai.js

npm install chai --save-dev
const sum = require('../src/sum.js');
const expect = require('chai').expect;

describe('测试 sum(1,2)', function () {
  it('sum(1+2) 应该等于 3', function () {
    expect(sum(1,2)).to.be.equal(3);
  });
});

测试脚本通常包含多个describe块,每个块都含有一个it块,
describe(testName, exceFunc)
describe 第一个参数是这个测试过程的名称,第二个参数应该是一个函数,它包含了我们要测试的内容,也就是我们要执行的过程。
it 是测试用例,表示一个单独的测试,是测试的最小单位。它是一个函数。第一个参数是测试用例的名称("1 加 1 应该等于 2")
,第二个参数是一个实际执行的函数。

2.4 运行测试脚本

这里我在package.json 中声明了执行脚本

"scripts": {
    "test": "mocha ./test/sum.test.js"
  }

也可以在项目目录直接执行

mocha ./test/sum.test.js

运行结果如图:

图片描述

三、对异步代码进行测试

3.1 对使用回调函数的异步请求进行测试

Mocha中测试异步代码比较简单,只需要在测试用例结束时调用一下回调函数即可,通常回调函数写作done(),这样、Mocha就能获知这时一个异步函数,回调时才认为测试结束。

新建async.js,这里GET一个存在的json文件,来作为一个异步过程。

const request = require('request');

module.exports = asyncProc = function (callback) {
  request('https://github.com/Will233/koa-template/blob/master/mock/data.json',function (err, res, body) {
    callback(err, res, body)
  });
}

测试脚本

const expect = require('chai').expect;
const request = require('request');

const asyncProc = require('../src/async.js');
describe('测试异步过程', function () {
  it('发送异步请求, response statusCode == 200', function (done){
    asyncProc(function (err, res, body) {
      expect(res.statusCode).to.be.equal(200)
      done()
    })
  });
});
mocha ./test/async.test.js

运行结果如下:

图片描述

发现报错了。这里对异步代码进行测试时需要注意一点,Mocha默认一个单元测试最多执行2000ms,超时会报错。可在执行的时候用-t--timeout 指定超时阈值。
提高超时时间:

mocha -t 5000 ./test/async.test.js

运行结果如下:
图片描述

3.2 对使用Promise的异步函数进行测试

Mocha 同样支持了对返回promise的异步代码进行测试。
我们改造一下上面请求的代码,使其返回promise。

// async.js
const asyncPromise = function () {
  return new Promise(function (resolve, reject) {
    request('https://github.com/Will233/koa-template/blob/master/mock/data.json',function (err, res, body) {
        if (err) {
          reject(err)
        } else {
          resolve(res)
        }
    });
  });
}

编写测试用例:

describe('测试异步过程 Promise', function () {
  it('发送异步请求, response statusCode == 200', function (){
    return asyncPromise().then(function (res) {
      expect(res.statusCode).to.be.equal(200);
    });
  });
});

运行结果如下:
图片描述

四、结语

Mocha 作为一个强大的测试框架,还有很多特性。以后慢慢了解咯。


will233
538 声望3 粉丝

天下大事,必作于细。