- JasmineJS 教程
- JasmineJS - 主页
- JasmineJS - 概述
- JasmineJS - 环境设置
- JasmineJS - 编写文本和执行
- JasmineJS - BDD 架构
- JasmineJS - 测试构建块
- JasmineJS - 匹配器
- JasmineJS - 跳过块
- JasmineJS - 平等检查
- JasmineJS - 布尔检查
- JasmineJS - 顺序检查
- JasmineJS - 空检查
- JasmineJS - 不平等检查
- JasmineJS - 不是数字检查
- JasmineJS - 异常检查
- JasmineJS - beforeEach()
- JasmineJS - afterEach()
- JasmineJS - 间谍
- JasmineJS 有用资源
- JasmineJS - 快速指南
- JasmineJS - 有用的资源
- JasmineJS - 讨论
JasmineJS - 匹配器
Jasmine 是一个测试框架,因此它始终旨在将 JavaScript 文件或函数的结果与预期结果进行比较。Matcher 在 Jasmine 框架中的工作原理类似。
匹配器是在实际输出和预期输出之间进行布尔比较的 JavaScript 函数。有两种类型的匹配器:内置匹配器和自定义匹配器。
内置匹配器
Jasmine框架内置的匹配器称为内置匹配器。用户可以轻松地隐式使用它。
以下示例展示了 Inbuilt Matcher 在 Jasmine 框架中的工作原理。我们在前一章中已经使用了一些匹配器。
describe("Adding single number ", function () { //example of toEqual() matcher it("should add numbers",function() { expect(nested.add(5)).toEqual(5); expect(nested.add(5)).toEqual(10); }); it("should add numbers",function() { expect(nested.addAny(1,2,3)).toEqual(6); }); }
在示例中,toEqual() 是内置匹配器,它将add()和addAny()方法的结果与传递给toEqual()匹配器的参数进行比较。
自定义匹配器
Jasmine 内置系统库中不存在的匹配器称为自定义匹配器。自定义匹配器需要显式定义()。在下面的示例中,我们将了解自定义匹配器的工作原理。
describe('This custom matcher example', function() { beforeEach(function() { // We should add custom matched in beforeEach() function. jasmine.addMatchers ({ validateAge: function() { Return { compare: function(actual,expected) { var result = {}; result.pass = (actual > = 13 && actual < = 19); result.message = 'sorry u are not a teen '; return result; } }; } }); }); it('Lets see whether u are teen or not', function() { var myAge = 14; expect(myAge).validateAge(); }); it('Lets see whether u are teen or not ', function() { var yourAge = 18; expect(yourAge).validateAge(); }); });
在上面的示例中,validateAge()作为匹配器,实际上是在某个范围内验证您的年龄。在此示例中,validateAge() 用作自定义匹配器。将此 JS 文件添加到SpecRunner.html中并运行相同的文件。它将生成以下输出。