小編給大家分享一下PHPStorm中如何對(duì)nodejs項(xiàng)目進(jìn)行單元測(cè)試,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

安裝必要的包
nodejs的單元測(cè)試最常用的是使用mocha包。首先確保你本地安裝nodejs,之后按照mocha包。
npm install mocha -g
然后還需要安裝相關(guān)的斷言工具,Node.js中常用的斷言庫(kù)有:
assert: TDD風(fēng)格
should: BDD風(fēng)格
expect: BDD風(fēng)格
chai: BDD/TDD風(fēng)格
使用npm install安裝這些斷言庫(kù)其中之一即可。
PHPStorm配置nodejs單元測(cè)試環(huán)境
在PHPStorm中選擇菜單:Run -> Edit Configurations,點(diǎn)擊右上角添加mocha。

分別填寫(xiě)下面幾項(xiàng),關(guān)于mocha單元測(cè)試可以參考官網(wǎng):https://mochajs.org/
Name: 隨便一個(gè)運(yùn)行配置的名稱(chēng),如MochaTest
Working directory: 當(dāng)前項(xiàng)目目錄
Mocha package: Mocha安裝包的目錄,node_modules\mocha
User interface: 測(cè)試類(lèi)型,這里選擇TDD(對(duì)應(yīng)assert庫(kù))
Test directory: 這一項(xiàng)可以選擇測(cè)試目錄或文件
All in directory: 整個(gè)目錄都進(jìn)行測(cè)試
File patterns: 某種模式的文件,可以填正則表達(dá)式
Test file: 某個(gè)特定的測(cè)試文件
填寫(xiě)完成并且沒(méi)有報(bào)錯(cuò)后點(diǎn)擊OK。
Nodejs進(jìn)行單元測(cè)試
這里我們選擇assert庫(kù),TDD模式進(jìn)行單元測(cè)試。在上面選定的Test directory目錄下新建一個(gè)測(cè)試文件test.js.
const assert = require('assert');
// 測(cè)試Array類(lèi)型的方法
suite('Array', function() {
// 測(cè)試 indexOf方法
suite('#indexOf()', function() {
// 測(cè)試用例
test('should return -1 when not present', function() {
assert.equal(-1, [1, 2, 3].indexOf(4));
});
});
});點(diǎn)擊選擇Mocha運(yùn)行,在PHPStorm下面的輸出框中有測(cè)試的結(jié)果,綠色表示通過(guò),紅色表示失敗。

斷言庫(kù)的使用
mocha進(jìn)行單元測(cè)試的時(shí)候,除了能夠使用assert斷言庫(kù),只要斷言代碼中拋出Error,mocha就可以正常工作。
assert庫(kù):TDD風(fēng)格
下面列舉assert庫(kù)中常用的斷言函數(shù),詳情可參考官網(wǎng):https://www.npmjs.com/package/assert
assert.fail(actual, expected, message, operator)
assert(value, message), assert.ok(value, [message])
assert.equal(actual, expected, [message])
assert.notEqual(actual, expected, [message])
assert.deepEqual(actual, expected, [message])
assert.notDeepEqual(actual, expected, [message])
assert.strictEqual(actual, expected, [message])
assert.notStrictEqual(actual, expected, [message])
assert.throws(block, [error], [message])
assert.doesNotThrow(block, [message])
assert.ifError(value)
其中的參數(shù)說(shuō)明如下:
value: 實(shí)際值
actual: 實(shí)際值
expected: 期望值
block: 語(yǔ)句塊
message: 附加信息
BDD風(fēng)格should.js斷言庫(kù)
安裝方法:npm install should --save-dev,官網(wǎng)地址:https://github.com/shouldjs/should.js
const should = require('should');
const user = {
name: 'tj'
, pets: ['tobi', 'loki', 'jane', 'bandit']
};
user.should.have.property('name', 'tj');
user.should.have.property('pets').with.lengthOf(4);
// If the object was created with Object.create(null)
// then it doesn't inherit `Object.prototype`, so it will not have `.should` getter
// so you can do:
should(user).have.property('name', 'tj');
// also you can test in that way for null's
should(null).not.be.ok();
someAsyncTask(foo, function(err, result){
should.not.exist(err);
should.exist(result);
result.bar.should.equal(foo);
});should庫(kù)可以使用鏈?zhǔn)秸{(diào)用,功能非常強(qiáng)大。相關(guān)文檔參考:http://shouldjs.github.io/
user.should.be.an.instanceOf(Object).and.have.property('name', 'tj');
user.pets.should.be.instanceof(Array).and.have.lengthOf(4);常用的should斷言方法:
無(wú)意義謂詞,沒(méi)作用增加可讀性:.an, .of, .a, .and, .be, .have, .with, .is, .which
should.equal(actual, expected, [message]): 判斷是否相等
should.notEqual(actual, expected, [message]): 判斷是否不相等
should.strictEqual(actual, expected, [message]): 判斷是否嚴(yán)格相等
should.notStrictEqual(actual, expected, [message]): 判斷是否嚴(yán)格不相等
should.deepEqual(actual, expected, [message]): 判斷是否遞歸相等
should.notDeepEqual(actual, expected, [message]): 判斷是否遞歸不想等
should.throws(block, [error], [message]): 判斷是否拋出異常
should.doesNotThrow(block, [message]): 判斷是否不拋出異常
should.fail(actual, expected, message, operator): 判斷是否不等
should.ifError(err): 判斷是否為錯(cuò)誤
should.exist(actual, [message]): 判斷對(duì)象是否存在
should.not.exist(actual, [message]): 判斷對(duì)象是否不存在
另外should還提供了一系列類(lèi)型判斷斷言方法:
// bool類(lèi)型判斷
(true).should.be.true();
false.should.not.be.true();
// 數(shù)組是否包含
[ 1, 2, 3].should.containDeep([2, 1]);
[ 1, 2, [ 1, 2, 3 ]].should.containDeep([ 1, [ 3, 1 ]]);
// 數(shù)字比較
(10).should.not.be.NaN();
NaN.should.be.NaN();
(0).should.be.belowOrEqual(10);
(0).should.be.belowOrEqual(0);
(10).should.be.aboveOrEqual(0);
(10).should.be.aboveOrEqual(10);
// Promise狀態(tài)判斷
// don't forget to handle async nature
(new Promise(function(resolve, reject) { resolve(10); })).should.be.fulfilled();
// test example with mocha it is possible to return promise
it('is async', () => {
return new Promise(resolve => resolve(10))
.should.be.fulfilled();
});
// 對(duì)象的屬性判斷
({ a: 10 }).should.have.property('a');
({ a: 10, b: 20 }).should.have.properties({ b: 20 });
[1, 2].should.have.length(2);
({}).should.be.empty();
// 類(lèi)型檢查
[1, 2, 3].should.is.Array();
({}).should.is.Object();幾種常見(jiàn)的測(cè)試風(fēng)格代碼舉例
BDD
BDD提供的接口有:describe(), context(), it(), specify(), before(), after(), beforeEach(), and afterEach().
describe('Array', function() {
before(function() {
// ...
});
describe('#indexOf()', function() {
context('when not present', function() {
it('should not throw an error', function() {
(function() {
[1, 2, 3].indexOf(4);
}.should.not.throw());
});
it('should return -1', function() {
[1, 2, 3].indexOf(4).should.equal(-1);
});
});
context('when present', function() {
it('should return the index where the element first appears in the array', function() {
[1, 2, 3].indexOf(3).should.equal(2);
});
});
});
});TDD
提供的接口有: suite(), test(), suiteSetup(), suiteTeardown(), setup(), and teardown():
suite('Array', function() {
setup(function() {
// ...
});
suite('#indexOf()', function() {
test('should return -1 when not present', function() {
assert.equal(-1, [1, 2, 3].indexOf(4));
});
});
});QUNIT
和TDD類(lèi)似,使用suite()和test()標(biāo)記測(cè)試永烈,包含的接口有:before(), after(), beforeEach(), and afterEach()。
function ok(expr, msg) {
if (!expr) throw new Error(msg);
}
suite('Array');
test('#length', function() {
var arr = [1, 2, 3];
ok(arr.length == 3);
});
test('#indexOf()', function() {
var arr = [1, 2, 3];
ok(arr.indexOf(1) == 0);
ok(arr.indexOf(2) == 1);
ok(arr.indexOf(3) == 2);
});
suite('String');
test('#length', function() {
ok('foo'.length == 3);
});以上是“PHPStorm中如何對(duì)nodejs項(xiàng)目進(jìn)行單元測(cè)試”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性?xún)r(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專(zhuān)為企業(yè)上云打造定制,能夠滿(mǎn)足用戶(hù)豐富、多元化的應(yīng)用場(chǎng)景需求。
標(biāo)題名稱(chēng):PHPStorm中如何對(duì)nodejs項(xiàng)目進(jìn)行單元測(cè)試-創(chuàng)新互聯(lián)
本文URL:http://chinadenli.net/article16/hhegg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站建設(shè)、用戶(hù)體驗(yàn)、微信公眾號(hào)、企業(yè)建站、網(wǎng)站策劃、網(wǎng)站改版
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容