美文网首页
网易云团队前端单元测试技术方案总结,测试人员必备知识

网易云团队前端单元测试技术方案总结,测试人员必备知识

作者: 软件测试小白 | 来源:发表于2021-12-11 19:35 被阅读0次

单元测试技术方案很多,不同工具之间有互相协同,也存在功能重合,给我们搭配测试方案带来不小的困难,而且随着 ES6, TypeScript 的出现,单元测试又增加了很多其他步骤,完整配置起来往往需要很大的时间成本。我希望通过对这些工具的各自作用的掌握,了解完整的前端测试技术方案。前端单元测试的领域也很多,这里主要讲对于前端组件如何进行单元测试,最后会主要介绍下对于 React 组件的一些测试方法总结。

  通用测试

单元测试最核心的部分就是做断言,比如传统语言中的 assert 函数,如果当前程序的某种状态符合assert 的期望此程序才能正常执行,否则直接退出应用。所以我们可以直接用 Node 中自带的 assert 模块做断言。

  用最简单的例子做个验证:

 function multiple(a, b) {

      let result = 0;

      for (let i = 0; i < b; ++i)

          result += a;

      return result;

  }

  const assert = require('assert');

  assert.equal(multiple(1, 2), 3));

  这种例子能够满足基础场景的使用,也可以作为一种单元测试的方法。

  nodejs 自带的 assert 模块提供了下面一些断言方法,只能满足一些简单场景的需要。

  assert.deepEqual(actual, expected[, message])

  assert.deepStrictEqual(actual, expected[, message])

  assert.doesNotMatch(string, regexp[, message])

  assert.doesNotReject(asyncFn[, error][, message])

  assert.doesNotThrow(fn[, error][, message])

  assert.equal(actual, expected[, message])

  assert.fail([message])

  assert.ifError(value)

  assert.match(string, regexp[, message])

  assert.notDeepEqual(actual, expected[, message])

  assert.notDeepStrictEqual(actual, expected[, message])

  assert.notEqual(actual, expected[, message])

  assert.notStrictEqual(actual, expected[, message])

  assert.ok(value[, message])

  assert.rejects(asyncFn[, error][, message])

  assert.strictEqual(actual, expected[, message])

  assert.throws(fn[, error][, message])

自带的 assert 不是专门给单元测试使用, 提供的错误信息文档性不好,上面的 demo 最终执行下来会产生下面的报告:

  $ node index.js

  assert.js:84

    throw new AssertionError(obj);

    ^

  AssertionError [ERR_ASSERTION]: 2 == 3

      at Object.<anonymous> (/home/quanwei/git/index.js:4:8)

      at Module._compile (internal/modules/cjs/loader.js:778:30)

      at Object.Module._extensions..js (internal/modules/cjs/loader.js:789:10)

      at Module.load (internal/modules/cjs/loader.js:653:32)

      at tryModuleLoad (internal/modules/cjs/loader.js:593:12)

      at Function.Module._load (internal/modules/cjs/loader.js:585:3)

      at Function.Module.runMain (internal/modules/cjs/loader.js:831:12)

      at startup (internal/bootstrap/node.js:283:19)

      at bootstrapNodeJSCore (internal/bootstrap/node.js:623:3)

  由于自带的模块依赖 Node 自身的版本,没办法自由升级,所以使用内置的包灵活性有时候不太够,另外我们很多断言函数也需要在浏览器端执行,所以我们需要同时支持浏览器和 Node 端的断言库。同时观察上面的输出可以发现,这个报告更像是程序的错误报告,而不是一个单元测试报告。而我们在做单元测时往往需要断言库能够提供良好的测试报告,这样才能一目了然地看到有哪些断言通过没通过,所以使用专业的单元测试断言库还是很有必要。

  chai

  chai 是目前很流行的断言库,相比于同类产品比较突出。chai 提供了 TDD (Test-driven development)和 BDD (Behavior-driven development) 两种风格的断言函数,这里不会过多介绍两种风格的优缺,本文主要以 BDD 风格做演示。

  TDD 风格的 chai

  var assert = require('chai').assert

    , foo = 'bar'

    , beverages = { tea: [ 'chai', 'matcha', 'oolong' ] };

  assert.typeOf(foo, 'string'); // without optional message

  assert.typeOf(foo, 'number', 'foo is a number'); // with optional message

  assert.equal(foo, 'bar', 'foo equal `bar`');

  assert.lengthOf(foo, 3, 'foo`s value has a length of 3');

  assert.lengthOf(beverages.tea, 3, 'beverages has 3 types of tea');

  chai 比 Node 自带的 assert 增加了一个断言说明参数,可以通过这个参数提高测试报告的可读性。

  $ node chai-assert.js

  /home/quanwei/git/learn-tdd-bdd/node_modules/chai/lib/chai/assertion.js:141

        throw new AssertionError(msg, {

        ^

  AssertionError: foo is a number: expected 'bar' to be a number

      at Object.<anonymous> (/home/quanwei/git/learn-tdd-bdd/chai-assert.js:6:8)

      at Module._compile (internal/modules/cjs/loader.js:778:30)

      at Object.Module._extensions..js (internal/modules/cjs/loader.js:789:10)

      at Module.load (internal/modules/cjs/loader.js:653:32)

      at tryModuleLoad (internal/modules/cjs/loader.js:593:12)

      at Function.Module._load (internal/modules/cjs/loader.js:585:3)

      at Function.Module.runMain (internal/modules/cjs/loader.js:831:12)

      at startup (internal/bootstrap/node.js:283:19)

      at bootstrapNodeJSCore (internal/bootstrap/node.js:623:3)

  BDD 风格的 chai

  chai 的 BDD 风格使用 expect 函数作为语义的起始,也是目前几乎所有 BDD 工具库都遵循的风格。

  chai 的 expect 断言风格如下:

  expect(foo).to.be.a('string');

  expect(foo).to.equal('bar');

  expect(foo).to.have.lengthOf(3);

  BDD 的思想就是写单元测试就像写产品需求,而不关心内部逻辑,每一个用例阅读起来就像一篇文档。例如下面的用例:

  1.foo 是一个字符串 ->expect(foo).to.be.a('string')

  2.foo 字符串里包含 'bar' ->expect(foo).to.include('bar')

  3.foo 字符串里不包含 'biz' -> expect(foo).to.not.include('biz')

  可以看到这种风格的测试用例可读性更强。

  其他的断言库还有 expect.js should.js better-assert , unexpected.js 这些断言库都只提供纯粹的断言函数,可以根据喜好选择不同的库使用。

  有了断言库之后我们还需要使用测试框架将我们的断言更好地组织起来。

  mocha 和 Jasmine

  mocha 是一个经典的测试框架(Test Framework),测试框架提供了一个单元测试的骨架,可以将不同子功能分成多个文件,也可以对一个子模块的不同子功能再进行不同的功能测试,从而生成一份结构型的测试报告。例如 mocha 就提供了describe 和 it 描述用例结构,提供了 before, after, beforeEach, afterEach 生命周期函数,提供了 describe.only ,describe.skip , it.only, it.skip 用以执行指定部分测试集。

  const { expect } = require('chai');

  const { multiple } = require('./index');

  describe('Multiple', () => {

      it ('should be a function', () => {

          expect(multiple).to.be.a('function');

      })

      it ('expect 2 * 3 = 6', () => {

          expect(multiple(2, 3)).to.be.equal(6);

      })

  })

测试框架不依赖底层的断言库,哪怕使用原生的 assert 模块也可以进行。给每一个文件都要手动引入 chai 比较麻烦 ,这时候可以给 mocha 配置全局脚本,在项目根目录 .mocharc.js 文件中加载断言库, 这样每个文件就可以直接使用 expect 函数了。

 // .mocharc.js

  global.expect = require('chai').expect;

  使用 mocha 可以将我们的单元测试输出成一份良好的测试报告 mocha *.test.js

  当出现错误时输出如下:

  因为运行在不同环境中需要的包格式不同,所以需要我们针对不同环境做不同的包格式转换,为了了解在不同端跑单元测试需要做哪些事情,可以先来了解一下常见的包格式。

  目前我们主流有三种模块格式,分别是 AMD, CommonJS, ES Module。

相关文章

  • 网易云团队前端单元测试技术方案总结,测试人员必备知识

    单元测试的技术方案很多,不同工具之间有互相协同,也存在功能重合,给我们搭配测试方案带来不小的困难,而且随着 ES6...

  • 前端单元测试技术方案总结

    作者:Daniel Bartholomae翻译:疯狂的技术宅原文:https://startup-cto.net/...

  • 前端必备测试技术总结

    [TOC] 单元测试 目的:单元测试能够让开发者明确知道代码结构原则:单一职责、接口抽离、层次分离断言库:保证最小...

  • 单元测试之断言

    单元测试之断言 作为前端开发,很少去自己写单元测试。对于单元测试的了解也很少,自学了一点关于单元测试断言的知识,有...

  • AndroidStudio测试(三)单元测试

    这篇文章本来想写技术贴,但是思来想去还是给大家呈上总结贴。 一:什么是单元测试? 官方定义:单元测试是开发人员编写...

  • 关于iOS单元测试几点Tips

    相关文章: 1、走出 iOS 单元测试的困境2、iOS单元测试--百度Hi iOS团队技术周报 一、单元测试有什么...

  • 11-12月份iOS团队目标达成情况

    团队目标 单元测试编写 路由表方案讨论 单元测试方案与代码编写 首先研究了苹果自带的XCTest,但是不是很符合。...

  • 前端单元测试介绍

    前言:公司团队希望前端做单元测试,说起来干前端这么长时间以来还从来没写过单元测试,网上找了些资料,what?这都是...

  • 软件测试技术常见问题汇总

    一、常见问题 1、 单元测试主要内容是什么? 单元测试大多数由开发人员来完成,测试人员技术背景较好或者开发系统软件...

  • 技术选型 & 架构设计

    技术选型 目标产品-产品特性、投资性技术 目标团队-技术背景 技术本身-解决核心问题、单元测试覆盖率、维护团队、社...

网友评论

      本文标题:网易云团队前端单元测试技术方案总结,测试人员必备知识

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