jest里的匹配器

你也可以使用Jest的“匹配器”來測試數(shù)據(jù)。有很多不同的匹配器,所以這篇文章只會介紹最常用的幾種。

普通匹配

最簡單的的測試方法就是看兩個比較值是否相等:

test('2加2等于',()=>{
? ? expect(2+2).toBe(4);
});

在這段代碼中,expect(2 + 2) 返回一個“expectation”對象。針對expectation對象,你除了調(diào)用匹配器,其他的你什么也做不了。在這段代碼中,.toBe(4)就是匹配器。當(dāng)Jest運行時,它會跟蹤所有的匹配器,如果有失敗的匹配就會打印出錯誤消息。

把toBe換成===效果是一樣的。如果你想檢查一個對象的值,那么就要用 toEqual 來代替了:

test('對象分配屬性',()=>{
? ? const data={one:1};
? ? data['two']=2;
? ? expect(data).toEqual({one:1,two:2});
});

toEqual 會遞歸的檢查數(shù);組或?qū)ο蟮拿恳粋€地方。

你同樣可以進行反向測試:

test('正數(shù)相加不為零',()=>{
? ? for(let a=1;a<10;a++){
? ? ? ? for(let b=1;b<10;b++){
? ? ? ? ? ? expect(a+b).not.toBe(0);
? ? ? ? }
? ? }
});

很多時候測試需要區(qū)分 undefined,null和false,但是你有不想做這些麻煩的事。那jest已經(jīng)為你準(zhǔn)備好了很多助手方法專門解決這些問題。
-- toBeNull 只匹配 null
-- toBeUndefined 只匹配 undefined
-- toBeDefined 是 toBeUndefined 的反匹配
-- toBeTruthy 匹配 if 語句期望得到 true 的
-- toBeFalsy 匹配 if 語句期望得到 false 的

舉個例子:

test('null',()=>{
? ? const n=null;
? ? expect(n).toBeNull();
? ? expect(n).toBeDefined();
? ? expect(n).not.toBeUndefined();
? ? expect(n).not.toBeTruthy();
? ? expect(n).toBeFalsy();
});
test('0',()=>{
? ? const z=0;
? ? expect(z).not.toBeNull();
? ? expect(z).toBeDefined();
? ? expect(z).not.toBeUndefined();
? ? expect(z).not.toBeTruthy();
? ? expect(z).toBeFalsy();
});

你應(yīng)該根據(jù)你的代碼來選擇最佳的匹配器。

數(shù)字的比較都用對應(yīng)的匹配器。

test('2加2',()=>{
? ? const value=2+2;
? ? expect(value).toBeGreaterThan(3);//大于匹配器
? ? expect(value).toBeGreaterThanOrEqual(3.5);//大于或等于匹配器
? ? expect(value).toBeLessThan(5);//小于匹配器
? ? expect(value).toBeLessThanOrEqual(4.5);//小于或等于匹配器
? ? // toBe 和 toEqual 對數(shù)字來說效果相等
? ? expect(value).toBe(4);
? ? expect(value).toEqual(4);
});

如果你不希望浮點數(shù)的測試存在誤差,請使用 toBeCloseTo 來代替 toEqual。

test('浮點數(shù)相加',()=>{
? ? const value=0.1+0.2;
? ? expect(value).not.toBe(0.3);// 錯誤的方法,因為存在誤差。
? ? expect(value).toBeCloseTo(0.3);// 正確的方法。
});

對于字符串你可以使用 toMatch 配合正則表達式。

test('team 中沒有 i ',()=>{
? ? expect('team').not.toMatch(/I/);
});
test('但是 Christoph 中有 stop',()=>{
? ? expect('Christoph').toMatch(/stop/);
});

測試數(shù)組是否包含特定的元素可以使用 toContain。

const shoppingList=[
? ? 'diapers',
? ? 'kleenex',
? ? 'trash bags',
? ? 'paper towels',
? ? 'beer',
];
test('shopping 列隊是有 beer 的',()=>{
? ? expect(shoppingList).toContain('beer');
});

如果你想測試某個函數(shù)被調(diào)用的時候是否會拋出錯誤,請使用 toThrow。

function compileAndroidCode(){
? ? throw new ConfigError('你使用了錯誤的JDK');
}
test('編譯 android',()=>{
? ? expect(compileAndroidCode).toThrow();
? ? expect(compileAndroidCode).toThrow(ConfigError);
? ? // 你還可以匹配完整的錯誤消息或正則表達式
? ? expect(compileAndroidCode).toThrow('你使用了錯誤的JDK');
? ? expect(compileAndroidCode).toThrow(/JDK/);
});

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容