成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

前端單元測試 實現(xiàn)教程 mocha + mochawesome + istanbul + sinon

AaronYuan / 3207人閱讀

摘要:為什么要寫單元測試減少提高代碼質量,保證你的代碼是可測試的放心重構當你每個方法都寫了單元測試的時候,你每一個改動都會影響相應的單元測試,這樣你不用費盡心思的考慮哪里會有影響,特別是復雜項目或非核心功能不易被測試到,從而導致的產生。

為什么要寫單元測試

減少bug

提高代碼質量,保證你的代碼是可測試的

放心重構

當你每個方法都寫了單元測試的時候,你每一個改動都會影響相應的單元測試,這樣你不用費盡心思的考慮哪里會有影響,特別是復雜項目或非核心功能(不易被測試到),從而導致bug的產生。

當你的代碼不可測試的時候,就得考慮你的代碼是否需要重構的。好的代碼應該是職責分明且單一,顆粒度小且易于測試。

當你重構時,特別是大范圍的重構,你就有勇氣和信心了。

那么單元測試需要有那些要素呢

測試框架

測試報表

測試覆蓋率

斷言

mock

測試框架選用 mocha 官方文檔

安裝

npm install mocha

package.json

"scripts": {
        "test": "mocha --recursive --require babel-core/register tests/Js/test"
    }

mocha默認會找到項目的根目錄下的 test目錄,但是很多人項目目錄中單元測試目錄并不是test,而是在/tests/Js/test中,在scripts中,后面加上單元測試路徑,就可以修改默認地址

recursive參數(shù)代表查找 目錄的所有子目錄下的單元測試,否則只會查找當前目錄下的單元測試

node中并不支持某些es6語法,需要通過babel編譯,所以需要添加 --require babel-core/register

同時需要在項目根目錄添加.babelrc文件

{
  "presets": [ "es2015" ]
}

現(xiàn)在在 tests/Js/test目錄下創(chuàng)建一個文件 test.js

var assert = require("assert");
describe("Array", function() {
  describe("#indexOf()", function() {
    it("should return -1 when the value is not present", function() {
      assert.equal([1,2,3].indexOf(4), -1);
    });
  });
});

命令行中執(zhí)行 npm run test 結果如下

以上我們知道了如何引入前端測試框架,es6語法問題,執(zhí)行路徑問題

有時候命令行的結果看著不明了,想要輸出測試報告呢
這時候可以使用 mochawesome
安裝

npm install --save-dev mochawesome

package.json

"scripts": {
        "test": "mocha --recursive --reporter mochawesome --require babel-core/register tests/Js/test"
    }

在scripts命令中,添加 --reporter mochawesome
執(zhí)行命令

npm run test

結果如圖,將會生成 html文件和json文件

"代碼覆蓋率"(code coverage)。它有四個測量維度。

行覆蓋率(line coverage):是否每一行都執(zhí)行了

函數(shù)覆蓋率(function coverage):是否每個函數(shù)都調用了

分支覆蓋率(branch coverage):是否每個if代碼塊都執(zhí)行了

語句覆蓋率(statement coverage):是否每個語句都執(zhí)行了

那么如何知道每個js的覆蓋率呢
這時候用到了 istanbul 和 babel-istanbul
安裝

npm install istanbul
npm install babel-istanbul

package.json

"scripts": {
     "test:cover": "babel-node ./node_modules/.bin/babel-istanbul cover _mocha -- tests/Js/* -R spec --recursive
    }

istanbul他也是不支持一些es6語法的,所以也需要babel轉譯
使用cover參數(shù)結合mocha,--代表后面參數(shù)傳遞給mocha

執(zhí)行命令

npm run test:cover

結果如圖

Mocha本身不帶斷言庫,所以必須先引入斷言庫。
我們這里使用 chai

npm install chai

chaijs有三種斷言風格,詳細查看官網

jquery作為大部分都在使用的庫,那么如何對這類的代碼進行單元測試呢
比如以下代碼
hide-element.js

export const hideElement = ($element) => {
  $element.on("click", ".hide", function() {
    $(this).hide();
  });
};

首先node環(huán)境和瀏覽器環(huán)境是不一樣的,所以我們跑這類的單元測試就需要模擬出瀏覽器環(huán)境
我們需要安裝 jsdom

npm install jsdom

test.js 如下

const assert = require("chai").assert;
const { hideElement } = require("xxxx/hide-element.js");
describe("test:hide-element.js", function(done) {
  before(function() {
    let { JSDOM } = require("jsdom");
    let dom = new JSDOM(`
`,{ url: "http://127.0.0.1/", referrer: "http://127.0.0.1/", contentType: "text/html", userAgent: "Mellblomenator/9000", includeNodeLocations: true, }); global.window = dom.window; global.$ = require("jquery"); hideElement($("body")); }); it("click event", function() { $("body").find(".hide").trigger("click"); assert.equal($(".hide").css("display"), "none"); }); });

mocha 由 describe,it基本元素組成

mocha 有四個鉤子函數(shù) before,after,beforeEach,afterEach

因為node中引入依賴時會緩存模塊,初始化jsdom環(huán)境時,最好在before中,防止污染jsdom環(huán)境,導致不同的單元測試之間互相影響

需要測試的代碼中依賴了其他的模塊時,為了測試需要測試的代碼,而不去關心依賴的模塊,這時候我們需要 sinon 去mock掉相關依賴

demo.js

import api from "api";
export const demo = (arg) => {
    if (arg == 1) {
      return api.get({
        params: params
      });
    }
    
    return "ok";
};

test.js

import { demo } from "xx/demo.js";
const assert = require("chai").assert;
const sinon = require("sinon");
import api from "api";

describe("demo", function() {
  it("demo(1)", function() {
    //mock api的get方法,并且指定返回值為 "N"
    let apiGet = sinon.stub(api, "get").returns("N");
    let expectedParams = {params: "yes"};
    let res = demo(1);
    //automate clean-up,防止影響其他單元測試
    apiGet.restore();
    //斷言調用api.get 是傳入的參數(shù)為 {params: "yes"}
    sinon.assert.calledWith(apiGet, expectedParams);
    
    assert.equal(res, "N");
  });
});

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉載請注明本文地址:http://systransis.cn/yun/93583.html

相關文章

  • 如何使用 mochasinon 集成單元測試--單元測試示例及分析(上)

    摘要:使用集成單元測試上項目地址安裝依賴測試框架可視化報表覆蓋率替換依賴斷言命令命令命令執(zhí)行單元測試,并打開測試報告頁面和覆蓋率頁面執(zhí)行生成單元測試覆蓋率并打開執(zhí)行單個單元測試文 使用 mocha 集成單元測試(上) 項目地址:https://github.com/Jay-tian/j... 安裝依賴 yarn add jquery mocha mochawesome istanbu...

    Caicloud 評論0 收藏0
  • mocha、chai、sinonistanbul實現(xiàn)100%單元測試覆蓋率

    摘要:加上測試覆蓋率檢查,就能夠提供足夠的信息,來斷言代碼的行為是否符合期望。測試的相關技術是程序的代碼覆蓋率工具,以土耳其最大城市伊斯坦布爾命名。 showImg(https://segmentfault.com/img/remote/1460000010260434); 敏捷軟件開發(fā)中,最重要實踐的就是測試驅動開發(fā),在單元測試層面,我們試著實現(xiàn)一個重要的指標就是測試覆蓋率。測試覆蓋率衡量...

    Yuanf 評論0 收藏0
  • 【Node Hero】9. Node.js 單元測試

    摘要:基本上,測試金字塔描述你應該編寫單元測試集成測試和端到端測試。集成測試要比端到端測試多,單元測試甚至要更多一些。應用程序單元測試編寫單元測試,是為了看看給定的模塊單元是否工作。 本文轉載自:眾成翻譯譯者:網絡埋伏紀事鏈接:http://www.zcfy.cc/article/1754原文:https://blog.risingstack.com/node-hero-node-js-un...

    104828720 評論0 收藏0
  • 前端單元測試初探

    摘要:本文只討論單測的范疇,對集成測試有興趣的話,可以看下的集成測試代碼。前端單測現(xiàn)狀測試本質上就是假定一個輸入,然后判斷得到預期的輸出。 原文發(fā)于我的博客:https://github.com/hwen/blogS... 要不要寫單測? 關于這個 cnode 上就有個很有意思的討論 做個調查,你的 Node 應用有寫單測嗎? 看完這個應該會有結論?如果沒有,就回帖跟別人探討下~ 測試 測試...

    isLishude 評論0 收藏0
  • ES6+mocha+istanbul,針對ES6語法的帶覆蓋率檢查的mocha測試

    摘要:安裝注意版本為為支持語法安裝依賴包注意為了使支持語法,在加入注意為了使支持語法,在加入小貓快跳最終運行或都可以參考 安裝 mocha, chai,mochawesome,istanbul npm install mocha chai mochawesome [email protected] --save-dev 注意1: istanbul 版本為 ^1.0.0-alpha....

    wuyangnju 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<