匹配器的使用
Jest使用“匹配器”的机制让你可以使用各种方法进行测试 这篇文档将向你介绍一些常用的匹配器, 想要看到完整的列表,请查阅 expect API 的文档。
常用的匹配器
最简单测试一个值的方法是使用精确匹配的方法。
test('two plus two is four', () => {expect(2 + 2).toBe(4);});
在上面的代码中,expect (2 + 2) 返回了一个”预期”的对象。 你通常不会对这些期望对象调用过多的匹配器。 在此代码中,.toBe(4) 是匹配器。 当 Jest 运行时,它会跟踪所有失败的匹配器,以便它可以为你打印出很好的错误消息。
toBe使用 Object.is来进行精准匹配的测试。 If you want to check the value of an object, use toEqual:
test('对象赋值', () => {const data = {one: 1};data['two'] = 2;expect(data).toEqual({one: 1, two: 2});});
toEqual 递归检查对象或数组的每个字段。
tip
toEqual ignores object keys with undefined properties, undefined array items, array sparseness, or object type mismatch. To take these into account use toStrictEqual instead.
您还可以使用与匹配相反的 not 来进行测试:
test('adding positive numbers is not zero', () => {for (let a = 1; a < 10; a++) {for (let b = 1; b < 10; b++) {expect(a + b).not.toBe(0);}}});
真值
代码中的undefined, null, and false有不同含义,若你在测试时不想区分他们,可以用真值判断。 Jest提供helpers供你使用。
toBeNull只匹配nulltoBeUndefined只匹配undefinedtoBeDefined与toBeUndefined相反toBeTruthy匹配任何if语句为真toBeFalsy匹配任何if语句为假
例如:
test('null', () => {const n = null;expect(n).toBeNull();expect(n).toBeDefined();expect(n).not.toBeUndefined();expect(n).not.toBeTruthy();expect(n).toBeFalsy();});test('zero', () => {const z = 0;expect(z).not.toBeNull();expect(z).toBeDefined();expect(z).not.toBeUndefined();expect(z).not.toBeTruthy();expect(z).toBeFalsy();});
你应该使用最精确匹配的匹配器来测试你期望你的代码能干什么。
数字
大多数的比较数字有等价的匹配器。
test('two plus two', () => {const value = 2 + 2;expect(value).toBeGreaterThan(3);expect(value).toBeGreaterThanOrEqual(3.5);expect(value).toBeLessThan(5);expect(value).toBeLessThanOrEqual(4.5);// toBe and toEqual are equivalent for numbersexpect(value).toBe(4);expect(value).toEqual(4);});
对于比较浮点数相等,使用 toBeCloseTo 而不是 toEqual,因为你不希望测试取决于一个小小的舍入误差。
test('两个浮点数字相加', () => {const value = 0.1 + 0.2;//expect(value).toBe(0.3); 这句会报错,因为浮点数有舍入误差expect(value).toBeCloseTo(0.3); // 这句可以运行});});
字符串
您可以检查对具有 toMatch 正则表达式的字符串︰
test('there is no I in team', () => {expect('team').not.toMatch(/I/);});test('but there is a "stop" in Christoph', () => {expect('Christoph').toMatch(/stop/);});
数组和可迭代对象
你可以通过 toContain来检查一个数组或可迭代对象是否包含某个特定项:
const shoppingList = ['diapers','kleenex','trash bags','paper towels','milk',];test('shoppingList数组中包含milk', () => {expect(shoppingList).toContain('milk');expect(new Set(shoppingList)).toContain('milk');});
例外
若你想测试某函数在调用时是否抛出了错误,你需要使用 toThrow。
function compileAndroidCode() {throw new Error('you are using the wrong JDK!');}test('compiling android goes as expected', () => {expect(() => compileAndroidCode()).toThrow();expect(() => compileAndroidCode()).toThrow(Error);// You can also use a string that must be contained in the error message or a regexpexpect(() => compileAndroidCode()).toThrow('you are using the wrong JDK');expect(() => compileAndroidCode()).toThrow(/JDK/);// Or you can match an exact error message using a regexp like belowexpect(() => compileAndroidCode()).toThrow(/^you are using the wrong JDK$/); // Test failsexpect(() => compileAndroidCode()).toThrow(/^you are using the wrong JDK!$/); // Test pass});
tip
The function that throws an exception needs to be invoked within a wrapping function otherwise the toThrow assertion will fail.
以及更多
这些只是浅尝辄止。 匹配器的完整列表,请查阅 参考文档。
一旦你学会了如何使用匹配器后,接下来可以学习 Jest 是如何让你可以 测试异步代码的。
