亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

NodeJs下的測試框架Mocha的簡單介紹

 更新時(shí)間:2017年02月22日 16:22:21   作者:革新  
本篇文章主要介紹了NodeJs下的測試框架Mocha的簡單介紹,是目前最為流行的javascript框架之一,在本文我們重點(diǎn)介紹它在NodeJs上的使用。有興趣的可以了解一下。

介紹和代碼下載

Mocha在2011年發(fā)布,是目前最為流行的javascript框架之一,在本文我們重點(diǎn)介紹它在NodeJs上的使用。

如果你需要下載實(shí)例代碼,可以通過去官網(wǎng)查找。https://mochajs.org/

下載代碼后安裝依賴:

$ cd DemoOfMocha
$ npm install

代碼目錄結(jié)構(gòu)如圖所示:

您可以按照代碼目錄結(jié)構(gòu)在根目錄新建lib文件夾和test文件夾,再在test文件夾中新建lib文件夾,然后通過npm init命令來生成package.json,也可以先將代碼下載下來跑一下

第一個測試

現(xiàn)在在lib目錄下新建一個sum.js文件

exports.sum =function (a,b) {
 return a+b
}

接下來測試這個腳本,在test目錄下的lib文件夾中新建測試腳本:sum.js

//test/lib/sum.js

var sum = require('../../lib/sum')
var assert = require('assert')

describe('和函數(shù)的測試',function () {
 it('1加1應(yīng)該等于2',function () {
 var expect=10;
 assert.equal(sum(1,1),expect);
 })
})

上面的代碼是測試腳本,測試腳本可以獨(dú)立執(zhí)行,測試腳本里應(yīng)該包含一個或者多個 describe 塊,每個describe塊也應(yīng)該包含一個或者多個 it 塊

describe 塊是“ 測試套件”,表示一組相關(guān)的測試,是一個函數(shù),第二個是實(shí)際可以執(zhí)行的函數(shù)

It 塊是“測試用例” 表示一個單獨(dú)的測試,測試的最小單位,也是一個函數(shù),第一參數(shù)是測試用例的名稱或說明,第二個參數(shù)是實(shí)際可以執(zhí)行的函數(shù)

assert 是斷言包(斷言包有很多種,這里我使用NodeJs自帶的斷言包),判斷測試代碼的執(zhí)行結(jié)果和預(yù)期的結(jié)果是否一致,不一致的話拋出一個錯誤,在我們的測試腳本中,sum(1,1),結(jié)果應(yīng)該等于2

我們在這里介紹一下Assert的斷言模塊的一些函數(shù)

assert.fail(actual, expected, message, operator)

使用指定操作符測試actual(真實(shí)值)是否和expected(期望值)一致。

assert.ok(value, [message])

測試實(shí)際值是否為true,和assert.equal(true, value, message);作用一致

assert.equal(actual, expected, [message])

使用等值比較操作符( == )測試真實(shí)值是否淺層地(shallow),強(qiáng)制性地(coercive)和預(yù)期值相等。

assert.notEqual(actual, expected, [message])

使用不等比較操作符( != )測試真實(shí)值是否淺層地(shallow),強(qiáng)制性地(coercive)和預(yù)期值不相等。

assert.deepEqual(actual, expected, [message])

測試真實(shí)值是否深層次地和預(yù)期值相等。

assert.notDeepEqual(actual, expected, [message])

測試真實(shí)值是否深層次地和預(yù)期值不相等。

assert.strictEqual(actual, expected, [message])

使用嚴(yán)格相等操作符 ( === )測試真實(shí)值是否嚴(yán)格地(strict)和預(yù)期值相等。

assert.notStrictEqual(actual, expected, [message])

使用嚴(yán)格不相等操作符 ( !== )測試真實(shí)值是否嚴(yán)格地(strict)和預(yù)期值不相等。

assert.throws(block, [error], [message])

預(yù)期block時(shí)拋出一個錯誤(error), error可以為構(gòu)造函數(shù),正則表達(dá)式或者其他驗(yàn)證器。

接下來我們在package.json中更新一下scripts字段

{
 "name": "DemoOfMocha",
 "version": "1.0.0",
 "description": "demo of mocha",
 "main": "index.js",
 "directories": {
 "test": "test"
 },
 "dependencies": {},
 "devDependencies": {},
 "scripts": {
 "test": "NODE_ENV=test mocha test/**/*.js"
 },
 "keywords": [
 "deom",
 "mocha"
 ],
 "author": "wjszxli",
 "license": "ISC"
}

我們通過npm命令去安裝MochaJS

$ npm install mocha --save-dev

我們添加了運(yùn)行測試的命令,接下來通過命令來獲得測試報(bào)告

$ npm test

測試報(bào)告如下:

這樣,我們第一個測試就成功了

讓測試報(bào)告變得更漂亮

我們可以使用mochawesome模塊,生成漂亮的HTML格式的報(bào)告,如圖:

通過如下命令進(jìn)行安裝mochawesome

$ npm install --save-dev mochawesome

然后更新在package.json中的scripts字段

 "name": "DemoOfMocha",
 "version": "1.0.0",
 "description": "demo of mocha",
 "main": "index.js",
 "directories": {
 "test": "test"
 },
 "dependencies": {},
 "devDependencies": {
 "mocha": "^3.2.0",
 "mochawesome": "^2.0.4"
 },
 "scripts": {
 "test": "NODE_ENV=test mocha test/**/*.js --reporter mochawesome"
 },
 "keywords": [
 "deom",
 "mocha"
 ],
 "author": "wjszxli",
 "license": "ISC”
}

運(yùn)行測試命令,測試報(bào)表就在mochawesome-reports中生成了

用瀏覽器打開下的html頁面,我們會看到漂亮的測試報(bào)告

異步測試

Mocha默認(rèn)每個測試用例最多執(zhí)行2000毫秒,2000毫秒之后沒有得到結(jié)果,就會報(bào)錯,如果涉及到異步操作的測試用例,2000毫秒是不夠的,這個時(shí)候我們需要用 -t 或 —timeout 參數(shù)指定超時(shí)門檻

我們可以修改在package.json中的scripts字段(我們這里改成3000毫秒)

"scripts": {
 "test": "NODE_ENV=test mocha -t 3000 timeout test/**/*.js --reporter mochawesome”
},

寫一個異步測試腳本

//test/lib/timeout.js


var assert = require('assert')

describe('測試應(yīng)該3000毫秒后結(jié)束',function () {
 it('測試應(yīng)該3000毫秒后結(jié)束',function (over) {
 var a=false;
 var b = function () {
  a=true;
  assert.ok(a);
  over();
 };
 setTimeout(b,2500);
 })
})

這個測試用例在執(zhí)行 it 塊的時(shí)候傳入了一個參數(shù) over,在測試結(jié)束的時(shí)候 必須顯式的調(diào)用這個函數(shù),告訴Mocha測試結(jié)束了,否則Mocha就會等到超時(shí)結(jié)束的時(shí)候報(bào)錯。

輸入命令運(yùn)行測試用例

我們也可以測試異步請求內(nèi)部地址或者外部的接口,這里我們請求內(nèi)部地址為例子:

 在根目錄新建:app.js

var express = require('express')
var app = express();

app.get('/api/test',function (req,res) {
 res.send({})
})

var port = process.env.PORT || 3000

if (process.env.NODE_ENV !== 'test') {
 app.listen(port);
 console.log('start from http://localhost:' + port)
} else {
 module.exports = app;
}

在test目錄下的lib文件夾中新建 async.js

//test/lib/async.js

var http = require('http')
var assert = require('assert')
var request = require('superagent');

describe("測試異步請求",function () {
 it("測試異步請求返回一個對象",function (next) {
 request
  .get('http://localhost:3000/api/test')
  .end(function(err, res){
  //expect(res).to.be.an('object');
  console.log(res.body);
  assert.deepEqual(res.body,Object)
  next();
  });
 })
})

測試結(jié)果

Mocha支持對Promist的測試,允許直接返回Promise,等到他的狀態(tài)發(fā)生變化之后,再執(zhí)行斷言

//test/lib/promise.js

var fetch = require('node-fetch');
var http = require('http')
var assert = require('assert')

describe('Promise 異步測試',function () {
 it('異步Promise返回一個對象',function () {
 return fetch('http://localhost:3000/api/test')
  .then(function(res) {
  return res.json();
  }).then(function(json) {
  console.log(json)
  assert.deepEqual(json,{});
  });
 })
})

執(zhí)行測試

測試的鉤子

在 describe 塊之中,有四個測試用例的鉤子:before()、after()、beforeEach()和afterEach()。它們會在指定時(shí)間執(zhí)行。

describe('hooks', function() { 
 before(function() { 
 // 在當(dāng)前區(qū)塊的所有測試用例之前執(zhí)行 
 }); 
 after(function() { 
 // 在當(dāng)前區(qū)塊的所有測試用例之后執(zhí)行 
 }); 
 beforeEach(function() { 
 // 在當(dāng)前區(qū)塊的每個測試用例之前執(zhí)行 
 }); 
 afterEach(function() { 
 // 在當(dāng)前區(qū)塊的每個測試用例之后執(zhí)行 
 }); 
 //測試用例 
});

在test目錄下的lib文件夾中新建 hooks.js

//test/lib/hooks.js
var assert = require('assert')

describe('hook示例', function() {
 var foo = false;

 beforeEach(function() {
 foo = true;
 });

 it('修改foo要成功', function() {
 assert.ok(foo)
 });
});

測試結(jié)果

測試用例管理

如果項(xiàng)目有很多測試用例,但有的時(shí)候只希望運(yùn)行其中幾個,這個時(shí)候可以用 only 方法,describe 塊和 it 塊都允許 only 方法,表示只允許運(yùn)行帶有 only 的測試用例

在test目錄下的lib文件夾中新建 only.js

//test/lib/only.js

var sum = require('../../lib/sum')
var assert = require('assert')

describe('和函數(shù)的測試',function () {
 it('1加2應(yīng)該等于3',function () {
 var expect=3;
 assert.equal(sum(1,2),expect);
 })

 it.only('3加4應(yīng)該等于7',function () {
 var expect=7;
 assert.equal(sum(3,4),expect);
 })
})

測試結(jié)果:

還有 skip 方法,表示跳過指定的測試用例

在test目錄下的lib文件夾中新建 skip.js

//test/lib/only.js

var sum = require('../../lib/sum')
var assert = require('assert')

describe('和函數(shù)的測試',function () {
 it('5加6應(yīng)該等于11',function () {
 var expect=11;
 assert.equal(sum(5,6),expect);
 })

 it.skip('7加8應(yīng)該等于15',function () {
 var expect=15;
 assert.equal(sum(7,8),expect);
 })
})

測試結(jié)果如下,跳過的用 - 號表示

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Node.js中參數(shù)傳遞的兩種方式詳解

    Node.js中參數(shù)傳遞的兩種方式詳解

    這篇文章主要為大家介紹了Node.js中參數(shù)傳遞的兩種方式:GET方式和POST方式,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下
    2022-04-04
  • package.json各個屬性說明詳解

    package.json各個屬性說明詳解

    這篇文章主要介紹了package.json各個屬性說明詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03
  • 詳解nodejs微信jssdk后端接口

    詳解nodejs微信jssdk后端接口

    本篇文章主要介紹了詳解nodejs微信jssdk后端接口,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-05-05
  • node版本管理工具n包使用教程詳解

    node版本管理工具n包使用教程詳解

    這篇文章主要介紹了node版本管理工具n包使用教程詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-11-11
  • 基于NodeJS+MongoDB+AngularJS+Bootstrap開發(fā)書店案例分析

    基于NodeJS+MongoDB+AngularJS+Bootstrap開發(fā)書店案例分析

    這章的目的是為了把前面所學(xué)習(xí)的內(nèi)容整合一下,這個示例完成一個簡單圖書管理模塊,因?yàn)橹虚g需要使用到Bootstrap這里先介紹Bootstrap
    2017-01-01
  • 使用Node.js搭建靜態(tài)資源服務(wù)詳細(xì)教程

    使用Node.js搭建靜態(tài)資源服務(wù)詳細(xì)教程

    這篇文章主要介紹了使用Node.js搭建靜態(tài)資源服務(wù)器,需要的朋友可以參考下
    2017-08-08
  • npm的安裝與使用

    npm的安裝與使用

    這篇文章介紹了npm的安裝與使用,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • 使用Jasmine和Karma對AngularJS頁面程序進(jìn)行測試

    使用Jasmine和Karma對AngularJS頁面程序進(jìn)行測試

    這篇文章主要介紹了使用Jasmine和Karma對AngularJS頁面程序進(jìn)行測試的方法,以Node.js為環(huán)境,非常適合JavaScript的全棧開發(fā)時(shí)使用,需要的朋友可以參考下
    2016-03-03
  • 詳解nodejs中express搭建權(quán)限管理系統(tǒng)

    詳解nodejs中express搭建權(quán)限管理系統(tǒng)

    本篇文章主要介紹了詳解express搭建權(quán)限管理系統(tǒng),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • socket.io與pm2(cluster)集群搭配的解決方案

    socket.io與pm2(cluster)集群搭配的解決方案

    這篇文章主要給大家介紹了關(guān)于socket.io與pm2(cluster)集群搭配的解決方案,文中介紹的非常詳細(xì),對大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編一起來看看吧。
    2017-06-06

最新評論