单元测试是用来对一个模块、一个函数或者一个类来进行正确性检验的测试工做html
能够理解为对功能的基本验证node
目前node中的测试框架,通常使用的是 mocha + 断言库 chainpm
安装浏览器
npm install mocha -g
npm install mocha
npm install chai
复制代码
describe 是一个 用例测试集, 他能够进行嵌套markdown
describe('进行首页的测试', function() { // .... }) 复制代码
一个it对应一个单元测试用例app
it('测试接口xxx', function() { // .... }) 复制代码
only -- 在当前的父describe块下,只执行该单元的测试框架
skip -- 在当前的父describe块下,跳过该单元的测试异步
describe('Array', function() { describe.only('父describe块下只执行该测试单元', () => { it.skip('跳过的测试单元', () => { }); }) }) 复制代码
describe 和 it 均可以使用这两个方法async
测试集合上定义超时时间,会对这个测试集合中全部的测试用例和测试集合起做用函数
const sleep = time => new Promise(resolve => setTimeout(resolve, time)) it('timeout', async function () { this.timeout(1000) await sleep(3000) expect(true).to.be.ok }) 复制代码
提供了几个函数,在特定的事件发生时被触发
before()、after()、beforeEach()、afterEach()
同一个describe下的执行顺序为before、beforeEach、afterEach、after
before, after 执行一次
beforeEach,afterEach 每个测试用例都会触发一次
before(() => console.info('首页测试开始')) after(() => console.info('首页测试结束')) beforeEach('check check check ', function() { console.log('i am check') }) 复制代码
chai有三种断言风格,expect,should,assert, 个人项目使用的是 expect
列出几个经常使用的方法
方法 | 含义 |
---|---|
equal | 相等(严格比较) |
not | 取反 |
include | 包含 |
expect('username').to.be.a('string') expect(false).to.be.a('boolean') expect(obj).to.have.property('foo') 复制代码
项目中的大部分函数为异步的,这个须要借助 done 来处理
it(`处理异步请求`, (done) => { // ... done() }) 复制代码
异步函数在函数内部手动调用done()表示测试成功,done(err)表示测试出错
async await 能够不使用done
it('更新用户对于文章的态度', async () => { const result = await updateAttitude({ articleId: 123, userId: 131, status: 0}) expect(result).to.be.a('number') }) 复制代码
最多见的接口测试
it('获取某一个频道下的全部文章列表', async function () { const result = await chai .request(app) .get('/articles/3/1') .then((res) => { return res.body }) expect(result).to.have.property('data') }) 复制代码
生成测试报告使用的是 mochawesome 模块
"mocha:report": "mocha --reporter mochawesome" 复制代码
会自动在项目建立 一个 mochawesome-report 目录,
简单来讲,就是判断你的测试用例对于函数的覆盖程度
npm install -g istanbul
复制代码
生成测试率覆盖报告
istanbul cover _mocha -- -R spec
复制代码
注: 这里是 _mocha 不要丢掉这下划线
会在项目中自动建立 coverage 文件夹
在浏览器中打开
open coverage/lcov-report/index.html
复制代码
接口是确定须要编写测试用例的,至因而否须要对函数作处理,我的感受能够对重要的函数进行测试