最近軟件測試課上需要我們介紹一個測試工具划咐,因為我沉迷node,所以只好拿出這一套幸福感爆棚的測試框架了钧萍,Mocha & Chai褐缠。
Mocha
簡介
Mocha是一個能夠運行在Node和瀏覽器中的多功能的JavaScript測試框架。作為一個測試框架风瘦,最主要的工作是提供了豐富的測試報告模塊幫助問題的分析定位队魏,并且對斷言模塊進行了更方便的分類封裝。所以Mocha是能夠很輕松的調(diào)用selenium webdriver之類的測試工具的万搔。
開始
describe('example 1', function () {
it('1加1等于2', function () {
expect(add(1, 1)).to.be.equal(3);
})
});
這里是一個很簡單的小例子胡桨,是對加法進行單元測試。
describe
是測試套件瞬雹,表示一組相關(guān)的測試昧谊。它是一個函數(shù),第一個參數(shù)是測試套件的名稱酗捌,第二個參數(shù)是一個實際執(zhí)行的函數(shù)呢诬。主要是用 describe
來對代碼進行分塊。在保留字中有它的同功能關(guān)鍵字 context
胖缤。
it
是測試用例枝恋,表示一個單獨的測試吹截,是測試的最小單元。在一個 describe
中可以包含多個 it
。并且如果 it
中包含多個斷言台盯,第一個斷言出現(xiàn)錯誤時,后面的將不會執(zhí)行篙贸。在保留字中有它的同功能關(guān)鍵字 specify
君珠。
這里主要記錄一些我覺得比較有意思的部分,對于Mocha的系統(tǒng)講解就不贅述哆料,有興趣的可以看看Mocha.js官方文檔翻譯 —— 簡單澳迫、靈活、有趣 和 測試框架 Mocha 實例教程剧劝。
測試狀態(tài)
測試結(jié)果主要分為3種狀態(tài)橄登,成功、失敗、掛起拢锹。這里主要說一下掛起谣妻,掛起有可能是因為沒有傳入回調(diào)函數(shù)的測試用例,即 it
中沒有傳入回調(diào)函數(shù)卒稳。還有一種可能是沒有設(shè)置超時檢查的超時函數(shù)蹋半,所以我們需要考慮超時測試。
超時測試可以在套件級設(shè)置充坑,也可以在用例級設(shè)置和鉤子級設(shè)置减江。
// 在套件級設(shè)置,只要用例級沒有覆蓋則整個套件有效
describe('example 1', function () {
this.timeout(500);
it('不超過500ms', function(done) {
setTimeOut(done, 300);
})
});
// 在用例級設(shè)置
describe('example 2', function () {
it('不超過500ms', function(done) {
this.timeout(500);
setTimeOut(done, 300);
})
})
// 在鉤子級設(shè)置
describe('example 3', function () {
beforeEach(function(done) {
this.timeout(3000);
setTimeout(done, 2500)
})
})
異步測試
因為是基于nodejs的框架捻爷,所以異步是在所難免的辈灼。但是同樣可以promise來優(yōu)雅的將異步處理為同步了。
const assert = require('assert')
it('應(yīng)該結(jié)束這個測試用例', function (done) {
return new Promise(function (resolve) {
assert.ok(true)
resolve()
})
})
定制測試方案
在測試程序當(dāng)中也榄,可能會因為測試方案的改變巡莹,需要對某一些測試套件進行測試,而有一些套件不需要測試甜紫。這時候Mocha就提供了定制的功能降宅。
- 獨占模式(describe.only / it.only):設(shè)置后僅會運行獨占的測試套件或者用例。
- 跳過測試(describe.skip / it.skip):設(shè)置后會跳過相應(yīng)的測試套件或用例囚霸。
- 重試測試(this.retries(4)):可以通過這種方法把失敗的測試重新運行幾次腰根,設(shè)置方法與超時測試類似,可以在套件或者用例中設(shè)置拓型。但是這個特性被設(shè)計用于資源(數(shù)據(jù))不容易被仿造的端到端測試唠雕,不推薦單元測試。
測試報告
測試報告是測試過程當(dāng)中非常重要的產(chǎn)物吨述。Mocha提供了很多有趣的測試報告岩睁,設(shè)置測試報告的方法是:
$ mocha test.js --reporter landing
--reporter
后面填寫測試報告模板的名字,這里推薦一下landing和默認(rèn)的SPEC揣云,當(dāng)然接下來要介紹的就是效果更好的網(wǎng)頁測試報告捕儒。
首先需要安裝 mochawesome
,然后使用就行邓夕。
$ npm install --save mochawesome
$ mocha test.js --reporter mochawesome
會在該文檔中新建mochawesome-reports文檔刘莹,里面就是報告。
配置文件
通過配置文件焚刚,可以簡化我們的命令点弯。比如我們在mocha.opts中添加:
--reporter tap
--recursive
--growl
然后在運行 $ mocha
,就相當(dāng)于我們運行:
$ mocha --recursive --reporter tap --growl
如果測試用例不是在當(dāng)前目錄矿咕,可以在配置文件前寫文檔名抢肛。
file
--reporter tap
--recursive
--growl
Chai
Mocha作為測試框架可以使用多種斷言庫狼钮,這里我選用了Chai。chai.js支持BDD風(fēng)格的expect/should API以及TDD風(fēng)格的Assert API捡絮。但是should斷言是不支持IE的并且穩(wěn)定性也沒有expect好熬芜,所以更推薦使用expect斷言。
對于API的解釋可以查看Chai.js斷言庫API中文文檔