From f5394bbb7306c0e4b563be0dfb9ada55057f1d4a Mon Sep 17 00:00:00 2001 From: geekact Date: Thu, 22 Dec 2022 11:58:47 +0800 Subject: [PATCH] docs: show developers how to test model [skip ci] --- docs/_sidebar.md | 4 ++- docs/test.md | 90 ++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 93 insertions(+), 1 deletion(-) create mode 100644 docs/test.md diff --git a/docs/_sidebar.md b/docs/_sidebar.md index ac2a407..59f9aac 100644 --- a/docs/_sidebar.md +++ b/docs/_sidebar.md @@ -18,4 +18,6 @@ - [问题解答](/troubleshooting.md) -* [捐赠](/donate.md) +* [编写测试](/test.md) + +- [捐赠](/donate.md) diff --git a/docs/test.md b/docs/test.md new file mode 100644 index 0000000..9d8292e --- /dev/null +++ b/docs/test.md @@ -0,0 +1,90 @@ +前端的需求变化总是太快导致测试用例跟不上,甚至部分程序员根本就没想过为自己写的代码编写测试,他们心里总是想着`出错了再说`。对于要求拥有高质量体验的项目,测试是必不可少的,它能使得代码更加稳健,并且在新增功能和重构代码时,都无需太担心会破坏原有的逻辑。在多人协作的项目中,充足的测试可以让其他人员对相应的逻辑有更充分的了解。 + +## 测试框架 + +- [Vitest](https://cn.vitest.dev/) +- [Jest](https://jestjs.io/zh-Hans/) +- [Mocha](https://mochajs.org/) +- [node:test](https://nodejs.org/dist/latest-v18.x/docs/api/test.html#test-runner) node@18.8.0开始提供 + +## 准备工作 + +我们已经知道,foca 是基于 redux 存储数据的,所以在测试模型之前,需要先激活 store,并且在测试完毕后销毁以免影响其他测试。 + +```typescript +// test/model.test.ts +import { store } from 'foca'; + +beforeEach(() => { + store.init(); +}); + +afterEach(() => { + store.unmount(); +}); +``` + +## 单元测试 + +我们假设你已经写好了一个模型 + +```typescript +// src/models/myModel.ts +import { defineModel } from 'foca'; + +export const myModel = defineModel('my-model', { + initialState: { count: 0 }, + reducers: { + plus(state, step: number = 1) { + state.count += step; + }, + minus(state, step: number = 1) { + state.count -= step; + }, + }, +}); +``` + +对,它现在很简洁,但是已经满足测试条件了 + +```typescript +// test/model.test.ts +import { store } from 'foca'; +import { myModel } from '../src/models/myModel.ts'; + +beforeEach(() => { + store.init(); +}); + +afterEach(() => { + store.unmount(); +}); + +test('initial state', () => { + expect(myModel.state.count).toBe(0); +}); + +test('myModel.plus', () => { + myModel.plus(); + expect(myModel.state.count).toBe(1); + myModel.plus(5); + expect(myModel.state.count).toBe(6); + myModel.plus(100); + expect(myModel.state.count).toBe(106); +}); + +test('myModel.minus', () => { + myModel.minus(); + expect(myModel.state.count).toBe(-1); + myModel.minus(10); + expect(myModel.state.count).toBe(-11); + myModel.minus(28); + expect(myModel.state.count).toBe(-39); +}); +``` + +**只测试**业务上的那部分逻辑,每处逻辑分开测试,这就是 `Unit Test` 和你该做的。 + +## 覆盖率 + +对于大一些的项目,你很难保证所有逻辑都已经写进了测试,则建议打开测试框架的覆盖率功能并检查每一行的覆盖情况。一般情况下,覆盖率的报告会放到`coverage`目录,你只需要在浏览器中打开`coverage/index.html`就可以查看了。