摘要:為什么要寫單元測試減少提高代碼質量,保證你的代碼是可測試的放心重構當你每個方法都寫了單元測試的時候,你每一個改動都會影響相應的單元測試,這樣你不用費盡心思的考慮哪里會有影響,特別是復雜項目或非核心功能不易被測試到,從而導致的產生。
為什么要寫單元測試
減少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
摘要:使用集成單元測試上項目地址安裝依賴測試框架可視化報表覆蓋率替換依賴斷言命令命令命令執(zhí)行單元測試,并打開測試報告頁面和覆蓋率頁面執(zhí)行生成單元測試覆蓋率并打開執(zhí)行單個單元測試文 使用 mocha 集成單元測試(上) 項目地址:https://github.com/Jay-tian/j... 安裝依賴 yarn add jquery mocha mochawesome istanbu...
摘要:加上測試覆蓋率檢查,就能夠提供足夠的信息,來斷言代碼的行為是否符合期望。測試的相關技術是程序的代碼覆蓋率工具,以土耳其最大城市伊斯坦布爾命名。 showImg(https://segmentfault.com/img/remote/1460000010260434); 敏捷軟件開發(fā)中,最重要實踐的就是測試驅動開發(fā),在單元測試層面,我們試著實現(xiàn)一個重要的指標就是測試覆蓋率。測試覆蓋率衡量...
摘要:基本上,測試金字塔描述你應該編寫單元測試集成測試和端到端測試。集成測試要比端到端測試多,單元測試甚至要更多一些。應用程序單元測試編寫單元測試,是為了看看給定的模塊單元是否工作。 本文轉載自:眾成翻譯譯者:網絡埋伏紀事鏈接:http://www.zcfy.cc/article/1754原文:https://blog.risingstack.com/node-hero-node-js-un...
摘要:安裝注意版本為為支持語法安裝依賴包注意為了使支持語法,在加入注意為了使支持語法,在加入小貓快跳最終運行或都可以參考 安裝 mocha, chai,mochawesome,istanbul npm install mocha chai mochawesome [email protected] --save-dev 注意1: istanbul 版本為 ^1.0.0-alpha....
閱讀 1367·2021-11-15 11:45
閱讀 3134·2021-09-27 13:36
閱讀 2877·2019-08-30 15:54
閱讀 995·2019-08-29 12:38
閱讀 2915·2019-08-29 11:22
閱讀 2996·2019-08-26 13:52
閱讀 2041·2019-08-26 13:30
閱讀 594·2019-08-26 10:37