美文网首页
Jest QuickStart

Jest QuickStart

作者: AsaGuo | 来源:发表于2019-12-03 08:48 被阅读0次

    Jest是 Facebook 的一套开源的 JavaScript 测试框架, 它自动集成了断言、JSDom、覆盖率报告等开发者所需要的所有测试工具,是一款几乎零配置的测试框架。
    0.使用步骤
    0.1 初始化package.json

    npm init -y
    

    0.2 安装Jest及相关依赖

    npm install -D jest babel-jest @babel-core @babel-preset-env regenerator-runtime
    

    babel-jest、 babel-core、 regenerator-runtime、babel-preset-env这几个依赖是为了让我们可以使用ES6的语法特性进行单元测试,ES6提供的 import 来导入模块的方式,Jest本身是不支持的。

    0.3 添加.babelrc文件
    在项目的根目录下添加.babelrc文件,并在文件复制如下内容:

    {
     "presets": ["babel-preset-env"]
    }
    

    0.4 修改package.json中的test脚本

    "scripts": {
      "test": "jest"
    }
    

    0.5 编写你的第一个Jest测试

    //functions.js
    export default {
      sum(a, b) {
        return a + b;
      }
    }
    
    //functions.test.js
    import functions  from '../src/functions';
    
    test('sum(2 + 2) 等于 4', () => {
      expect(functions.sum(2, 2)).toBe(4);
    })
    

    0.6 运行
    运行npm run test, Jest会在shell中打印出以下消息:

     PASS  test/functions.test.js
      √ sum(2 + 2) 等于 4 (7ms)
    
    Test Suites: 1 passed, 1 total
    Tests:       1 passed, 1 total
    Snapshots:   0 total
    Time:        4.8s
    

    1.Jest 常用的几种断言:
    expect(functions.sum(2, 2)).toBe(4)为一句断言,Jest为我们提供了expect函数用来包装被测试的方法并返回一个对象,该对象中包含一系列的匹配器来让我们更方便的进行断言,上面的toBe函数即为一个匹配器。
    1.1 .not
    .not修饰符允许你测试结果不等于某个值的情况,这和英语的语法几乎完全一样,很好理解。

    //functions.test.js
    import functions  from '../src/functions'
    
    test('sum(2, 2) 不等于 5', () => {
      expect(functions.sum(2, 2)).not.toBe(5);
    })
    

    1.2 .toEqual()
    .toEqual匹配器会递归的检查对象所有属性和属性值是否相等,所以如果要进行应用类型的比较时,请使用.toEqual匹配器而不是.toBe。

    // functions.js
    export default {
      getAuthor() {
        return {
          name: 'LITANGHUI',
          age: 24,
        }
      }
    }
    
    // functions.test.js
    import functions  from '../src/functions';
    
    test('getAuthor()返回的对象深度相等', () => {
      expect(functions.getAuthor()).toEqual(functions.getAuthor());
    })
    
    test('getAuthor()返回的对象内存地址不同', () => {
      expect(functions.getAuthor()).not.toBe(functions.getAuthor());
    })
    

    1.3 .toHaveLength
    .toHaveLength可以很方便的用来测试字符串和数组类型的长度是否满足预期。

    // functions.js
    export default {
      getIntArray(num) {
        if (!Number.isInteger(num)) {
          throw Error('"getIntArray"只接受整数类型的参数');
        }
    
        let result = [];
        for (let i = 0, len = num; i < len; i++) {
          result.push(i);
        }
        
        return result;
      }
    }
    
    // functions.test.js
    import functions  from '../src/functions';
    
    test('getIntArray(3)返回的数组长度应该为3', () => {
      expect(functions.getIntArray(3)).toHaveLength(3);
    })
    

    1.4 .toThrow
    .toThorw可能够让我们测试被测试方法是否按照预期抛出异常,但是在使用时需要注意的是:我们必须使用一个函数将将被测试的函数做一个包装,正如上面getIntArrayWrapFn所做的那样,否则会因为函数抛出导致该断言失败。

    // functions.test.js
    import functions  from '../src/functions';
    
    test('getIntArray(3.3)应该抛出错误', () => {
      function getIntArrayWrapFn() {
        functions.getIntArray(3.3);
      }
      expect(getIntArrayWrapFn).toThrow('"getIntArray"只接受整数类型的参数');
    })
    

    1.5 .toMatch
    .toMatch传入一个正则表达式,它允许我们用来进行字符串类型的正则匹配。

    // functions.test.js
    import functions  from '../src/functions';
    
    test('getAuthor().name应该包含"li"这个姓氏', () => {
      expect(functions.getAuthor().name).toMatch(/li/i);
    })
    

    相关文章

      网友评论

          本文标题:Jest QuickStart

          本文链接:https://www.haomeiwen.com/subject/nvgqgctx.html