From 294d5eef833d1714e1a5ade621f9572917a29b92 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=80=9D=E5=BF=A0?= Date: Tue, 15 Sep 2020 23:14:55 +0800 Subject: [PATCH] docs: test guide --- docs/guide/advance/backend.md | 2 +- docs/guide/advance/publish.md | 2 +- docs/guide/advance/quality.md | 2 +- docs/guide/advance/statistical.md | 2 +- docs/guide/advance/test.md | 166 ++++++++++++++++++++++++++++++ 5 files changed, 170 insertions(+), 4 deletions(-) create mode 100644 docs/guide/advance/test.md diff --git a/docs/guide/advance/backend.md b/docs/guide/advance/backend.md index db4843e01f..5a54bfb7ee 100644 --- a/docs/guide/advance/backend.md +++ b/docs/guide/advance/backend.md @@ -1,6 +1,6 @@ --- title: 后端应用集成 -order: 17 +order: 18 --- > 如果是阿里内部同学,请参考 [文档](https://yuque.alibaba-inc.com/ice/rdy99p/rpivf3) diff --git a/docs/guide/advance/publish.md b/docs/guide/advance/publish.md index 7520f4cae3..022a2c3332 100644 --- a/docs/guide/advance/publish.md +++ b/docs/guide/advance/publish.md @@ -1,6 +1,6 @@ --- title: 前端资源发布 -order: 15 +order: 16 --- > 如果是阿里内部同学,请参考 [文档](https://yuque.antfin-inc.com/ice/rdy99p/syvuzh) diff --git a/docs/guide/advance/quality.md b/docs/guide/advance/quality.md index 96231f17e1..12d7e85d8e 100644 --- a/docs/guide/advance/quality.md +++ b/docs/guide/advance/quality.md @@ -1,6 +1,6 @@ --- title: 代码质量保障 -order: 16 +order: 17 --- 为了保证代码质量,我们推荐使用 lint 相关的工具对代码进行检测,同时为了降低常规 lint 工具的使用成本,我们封装了 [@ice/spec](https://github.com/ice-lab/spec) 这个 npm 包。 diff --git a/docs/guide/advance/statistical.md b/docs/guide/advance/statistical.md index 3c74e2e159..3f4eab6d98 100644 --- a/docs/guide/advance/statistical.md +++ b/docs/guide/advance/statistical.md @@ -1,6 +1,6 @@ --- title: 页面埋点统计数据 -order: 18 +order: 19 --- > 阿里内部用户请参考:https://yuque.antfin-inc.com/ice/rdy99p/paswzc diff --git a/docs/guide/advance/test.md b/docs/guide/advance/test.md new file mode 100644 index 0000000000..db42ea9ec7 --- /dev/null +++ b/docs/guide/advance/test.md @@ -0,0 +1,166 @@ +--- +title: 编写单元测试 +order: 15 +--- + +icejs 支持 `icejs test` 命令,内置 Jest 配置提供前端的单元测试解决方案。 + +## 测试文件名约定 + +默认的 `testMatch` 为 `**/?*.(spec|test).(j|t)s?(x)`,即 icejs 将查找项目目录下所有符合条件的文件来执行测试 + +* 文件后缀为 `.spec.js`、`.spec.jsx`、`.spec.ts`、`.spec.tsx` +* 文件后缀为 `.test.js`、`.test.jsx`、`.test.ts`、`.test.tsx` + +## 使用 jest.config.js + +`icejs` 已经内置了 Jest 测试所需的配置,提供了开箱即用的测试能力,如果需要定制自己的 Jest 配置,可以在项目目录下添加 `jest.config.js` 文件。 + +```js +// jest.config.js +module.exports = { + testMatch: ['**/?*.e2e.js'], +}; +``` + +jest.config.js 中自定义配置最终将和默认配置进行合并,更多 Jest 相关配置,请参见[官网](https://jestjs.io/docs/en/configuration)。 + +## 使用 Jest 相关参数 + +`icejs` 通过约定的方式支持所有 Jest CLI 参数,相关参数增加 jest 前缀即可。 + +```bash +# Jest CLI 参数 --config= +$ icejs test --jest-config= + +# Jest CLI 参数 --watchAll +$ icejs test --jest-watchAll +``` + +## 编写测试用例 + +使用 Jest 提供的内置函数可以快速创建相应的测试用例 + +```js +function sum(a, b) { + return a + b; +} + +it('sum numbers', () => { + expect(sum(1, 2)).toEqual(3); + expect(sum(2, 2)).toEqual(4); +}); +``` + +在日常 React 项目开发中,上述简单的例子不足以满足测试需求,测试实践中的需求往往可以可以分为两类,根据相应的需求可以选择社区的工具来帮助完成测试。 + +* 通过快照进行 UI 测试 - 可以通过 Jest SnapShot 能力进行测试 +* DOM 交互测试 - 推荐使用 Enzyme,它提供了强大的 API 能力支持 UI 交互测试 + +### 使用 Snapshot 进行 UI 测试 + +Snapshot 测试是 Jest 提供的能力,可以自动生成组件 UI 输出的描述文件,确保你的 UI 不会发生意外的改变。 + +组件实现代码: + +```js +// ./src/test.js +import React from 'react'; + +export default function Test() { + return ( +
+ test +
+ ); +} +``` + +组件测试代码: + +```js +// ./test/snapshot.test.js +import React from 'react'; +import renderer from 'react-test-renderer'; +import Test from '../src/test'; + +it('renders', () => { + const tree = renderer + .create() + .toJSON(); + expect(tree).toMatchSnapshot(); +}); +``` + +在第一次运行后,Jest Snapshot 将会生成对应的 `.snap` 文件,如果组件的输出内容发生变更,则会导致测试用例无法通过。 + +### 使用 Enzyme 测试组件 + +Enzyme 是 Airbnb 提供的测试类库,它提供了一套简洁强大的 API。能够灵活操作 DOM,是 React 社区推荐的测试方案。 + +#### 准备工作 + +安装测试相关依赖包 + +```bash +$ npm install --save-dev enzyme enzyme-adapter-react-16 react-test-renderer +``` + +基于 React 开发的测试,需要安装对应的 React Adapter 来保证 enzyme 渲染的版本和项目中使用的版本一致,以 react 16 版本为例,需要进行如下设置: + +```js +import { configure } from 'enzyme'; +import Adapter from 'enzyme-adapter-react-16'; + +configure({ adapter: new Adapter() }); +``` + +如果不想每个测试用例都去定义一遍,可以将上述内容保存至 `src/setupTests.js` 文件中,并自定义 Jest 配置中的 `setupFilesAfterEnv` : + +```js +// jest.config.js +module.exports = { + setupFilesAfterEnv: ['/src/setupTests.js'], +}; +``` + +#### 组件测试用例 + +Enzyme 提供 shallow 方法对组件进行浅渲染,即它仅仅会渲染至虚拟 DOM,不会返回真实的 DOM 节点。多数情况下 shallow 方法就能满足测试需求。 + +组件实现代码: + +```js +import React, { useState } from 'react'; + +export default function Test() { + const [content, setContent] = useState('default content'); + function onContentChanged() { + setContent('test'); + } + return ( +
+ {content} + +
+ ); +} +``` + +使用 shallow 方法测试组件: + +```js +import React from 'react'; +import Test from '../src/test'; +import { shallow } from 'enzyme'; + +it('renders', () => { + const wrapper = shallow(); + const button = wrapper.find('button').at(0); + // 模拟触发 点击 事件,来改变当前的 state + button.simulate('click'); + expect(wrapper.find('span').at(0).text()).toBe('test'); +}); +``` + +更多测试用例编写,可以参考 [Enzyme 官网](https://airbnb.io/enzyme/)