The use of Mocha and chai

php中世界最好的语言
Release: 2018-03-19 16:30:09
Original
3149 people have browsed it

This time I will bring you the use of Mocha and chai. What are the precautions when using Mocha and chai? The following is a practical case, let’s take a look.

Introduction to Mocha

Mocha is one of the popular JavaScript testing frameworks through which you can add and run tests to ensure code quality

Mocha’sInstallation and configuration

Global installation of Mocha

npm install -g mocha
Copy after login

Also install Mocha in the project

npm install --save-dev mocha
Copy after login

Add the following to package.json Script:

"scripts": {
    "test": "mocha"
}
Copy after login

Usage of Mocha

Before using it, let’s take a look at the structure of the test project we use:
The use of Mocha and chai

As shown above As shown, the test files need to be placed in the test directory. When mocka is running, all js files in the test directory will be executed (limited to the level below test, for test/subtest Level one is not executed).

where index.js is our tested code:

/**
 * 加法函数
 * @param {第一个数} a 
 * @param {第二个数} b 
 */
function addNum(a,b){
    return a+b;
}
module.exports=addNum;
Copy after login

and index.test.js is our test code (note that a test is added to the name here, which is not necessary. Just to distinguish which are test files):

var addNum=require('../src/index')

describe('测试index.js', function() {
  describe('测试addNum函数', function() {
    it('两数相加结果为两个数字的和', function() {
       if(addNum(1,2)!==3){
         throw new Error("两数相加结果不为两个数字的和");
       }
    });
  });
});
Copy after login

Analyze the syntax of the above code:

The test script should include one or more describe blocks, and each describe block should Include one or more it blocks.
The describe block is called a "test suite" and represents a set of related tests. It is a function whose first parameter is the name of the test suite ("testindex.js") and the second parameter is a function that is actually executed.
It block is called "test case" (test case), which represents a single test and is the smallest unit of testing. It is also a function. The first parameter is the name of the test case ("The addition of two numbers is the sum of two numbers"), and the second parameter is a function that is actually executed.

In the above example, test the addNum function. If runs wrong, throws an exception

Run at this time

npm test
Copy after login
Copy after login
Copy after login

You can get the following results
The use of Mocha and chai

In order to see the result of the running error, we modify the code of index.js at this time:

function addNum(a,b){
    return a+b-1;
}
module.exports=addNum;
Copy after login

Run again

npm test
Copy after login
Copy after login
Copy after login

The results are as follows:
The use of Mocha and chai

Mocha and assertion library chai

In the above Mocha example, test failure is handled by throwing an exception, which is somewhat cumbersome. , so the assertion library emerged.
Here we introduce a commonly used assertion library chai.
It can be simply understood that this is an encapsulation of our exception-throwing method above. When the judgment fails, an exception will be thrown.
First install chai:

npm install --save-dev chai
Copy after login

Then let us use chai to modify the above index.test.js:

var expect = require('chai').expect;
var addNum=require('../src/index')

describe('测试index.js', function() {
  describe('测试addNum函数', function() {
    it('两数相加结果为两个数字的和', function() {
      expect(addNum(1,2)).to.be.equal(3);
    });
  });
});
Copy after login

The above grammar is very close to natural language, expect (expect) is an expression The result of an expression is equal to an expression.
Run

npm test
Copy after login
Copy after login
Copy after login

and get the following results:
The use of Mocha and chai

It can be seen that the assertion library in the picture also printed the expected result 3 and the actual result 2.
It would be much more cumbersome to use judgment to throw exceptions.

The above syntax is chai's expect syntax, which also has should syntax and asset syntax.
If you have used java and .NET before, you may be more comfortable with assets:

var assert = require('chai').assert;

assert.typeOf(foo, 'string');
assert.equal(foo, 'bar');
assert.lengthOf(foo, 3)
assert.property(tea, 'flavors');
assert.lengthOf(tea.flavors, 3);
Copy after login

The grammatical meaning of this is obvious, so I won’t go into details here.

Mocha's more uses

If you want to test a single test js, you can use:

mocha test/index.test.js
Copy after login

Or multiple js

mocha test/index.test.js test/add.test.js
Copy after login

Of course you can also use it Wildcard Test all js and jsx in a certain folder:

mocha 'test/some/*.@(js|jsx)'
Copy after login

Mocha and ES6

We are not using ES6 syntax above, so let us The code has been changed to ES6 syntax.
The index.js is:

/**
 * 加法函数
 * @param {第一个数} a 
 * @param {第二个数} b 
 */
export default (a,b)=>{
    return a+b-1;
}
Copy after login

and the index.test.js is:

import {assert} from 'chai'
import addNum from '../src/index'

describe('测试index.js',()=> {
  describe('测试addNum函数', ()=> {
    it('两数相加结果为两个数字的和', ()=> {
      assert.equal(addNum(1,2),3)
    })
  })
})
Copy after login

It is definitely not possible to run the mock directly at this time. We now need to install babel:

npm install babel-core babel-preset-es2015 --save-dev
Copy after login

Then, create a new .babelrc file under the project directory:

{
  "presets": [ "es2015" ]
}
Copy after login

Then change the script in package.json to:

"scripts": {
  "test": "mocha --compilers js:babel-core/register"
},
Copy after login

The --compilers parameter is used Specify the transcoder of the test script. This line of command means to first use the babel-core/register module to process the .js file when running mocha

Note:
--compilers will be used in the future Removed, the official said it is redundant, and as an alternative, the

"scripts": {
  "test": "mocha --require babel-core/register"
},
Copy after login

command has become simpler

Mocha测试用例执行的超时和高亮

Mocha默认每个测试用例最多执行2000毫秒,如果到时没有得到结果,就报错。以下命令设置超时时间为5000:

mocha -t 5000 index.test.js
Copy after login

Mocha默认会高亮显示超过75毫秒的测试用例,以下命令设置高亮判断的临界值:

mocha -s 1000 index.test.js
Copy after login

Mocha测试的钩子

Mocha在describe块之中,提供测试用例的四个钩子:before()、after()、beforeEach()和afterEach()。它们会在指定时间执行。

describe('测试index.js',()=> {
  before(()=>console.info("在本区块的所有测试用例之前执行"))

  after(()=>console.info("在本区块的所有测试用例之后执行"))

  beforeEach(()=>console.info("在本区块的每个测试用例之前执行"))

  afterEach(()=>console.info("在本区块的每个测试用例之后执行"))

  describe('测试addNum函数', ()=> {
    it('两数相加结果为两个数字的和', ()=> {
      assert.equal(addNum(1,2),3)
    })
  })
})
Copy after login

小结

关于mock和chai常用的一些玩法都讲了,更多的关于mock的测试结果输出格式,以及skip跳过测试和only仅测试当前用例等玩法就不讲述了。

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

Vue指令的使用

JS闭包的使用

The above is the detailed content of The use of Mocha and chai. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
About us Disclaimer Sitemap
php.cn:Public welfare online PHP training,Help PHP learners grow quickly!