首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

【Web技术】639- Web前端单元测试到底要怎么写?

我们看到的大多数教程都会讲单元测试的重要性、一些有代表性的测试框架 api 怎么使用,但在实际项目中单元测试要怎么下手?测试用例应该包含哪些具体内容呢?...项目用到的技术框架 该项目采用 react 技术栈,用到的主要框架包括:react、 redux、 react-reduxredux-actions、 reselect、 redux-saga、 seamless-immutable...actions 业务里面我使用redux-actions 来产生 action,这里用工具栏做示例,先看一段业务代码: import { createAction } from 'redux-actions...saga 是一种 es6 的生成函数 - Generator ,我们利用他来产生各种声明式的 effects ,由 redux-saga 引擎来消化处理,推动业务进行。...这个测试用例的步骤就是利用生成函数一步步的产生下一个 effect ,然后断言比较。 从上面的注释 3、4 可以看到, redux-saga 还提供了一些辅助函数来方便的处理分支断点。

3K30

React全家桶与前端单元测试艺术|洞见

Redux测试 (Model测试) Redux就是用一堆Reducer函数来reduce所有事件用来做全局Store的状态机(FSM)。...(小秘密:redux-devtools写完实现,在浏览器里打开,反过来还可以自动生成各种框架的测试代码,粘贴回来就行了。...我们用一个叫做Redux-saga的库来展现全家桶的异步测试怎么写,Redux模仿的目标是Elm architecture,但是简化掉了Elm的作用模型,只保留了同步模型,Redux-saga其实就是把...Saga是一种worker模式,很早之前在Java社区就存在了。Redux-saga抽象出来多种通用的作用比如call / takeEvery等等,然后有了这些作用,我们又可以愉快地判等了。...其他部分都可以开心地发同步事件了,此外有了Saga之后Redux终于有了“用事件触发事件”的机制了,只用redux,应用复杂到一定程度你一定会想这个问题的。

1.1K72
您找到你想要的搜索结果了吗?
是的
没有找到

React saga_react获取子组件ref

redux-saga安装 使用npm进行安装: npm install --save redux-saga 或者使用yarn: yarn add redux-saga redux-saga常用方法解释...如果存在副作用函数,那么我们需要首先处理副作用函数,然后生成原始的js对象。如何处理副作用操作,在redux中选择在发出action,到reducer处理函数之间使用中间件处理副作用。...(1)声明式的Effect redux-saga中最大的特点就是提供了声明式的Effect,声明式的Effect使得redux-saga监听原始js对象形式的action,并且可以方便单元测试,我们一一来看...通过使用Effect类函数,可以方便单元测试,我们不需要测试副作用函数的返回结果。只需要比较执行Effect方法后返回的描述对象,与我们所期望的描述对象是否相同即可。...不过这里call方法传入的函数fn可以是普通函数,也可以是generator。call方法应用很广泛,在redux-saga使用异步请求等常用call方法来实现。

4.5K30

React 单元测试策略及落地

市面关于React单元测试的文章,普遍停留在“可以如何写”和介绍工具的层面,既未回答“为何必须做单元测试”,也未回答“单元测试的最佳实践”两个关键问题。本文正是要对这两个问题作出回答。...TDD——单元测试的核心灵魂 以上回答了“为何要有单元测试”的问题,却没有回答“如何得到这些单元测试”。有同学可能问,你说要写单元测试,那么什么时候写这些单元测试呢?...第二部分:什么是好的单元测试 好,相信看到这里,你已经愿意为一套好的单元测试集而奋斗了。下一个摆在我们眼前的问题就是,“什么才是好的单元测试”,以及“如何写出这样的单元测试”了。...在实际的项目上副作用还有其他的中间层进行处理,比如 redux-thunk、redux-promise 等,本质是一样的,只不过 saga 在测试性上要好一些。这一层副作用怎么测试呢?...Emit 的事件、需要保存到 IndexDB 中去的数据等) 来自官方的错误姿势 redux-saga 官方提供了一个 util: CloneableGenerator用以帮我们写 saga 的测试。

1.1K20

redux-saga

作为一个Redux中间件,想让Redux应用中的副作用(即依赖/影响外部环境的不纯的部分)处理起来更优雅 二.设计理念 Saga像个独立线程一样,专门负责处理副作用,多个Saga可以串行/并行组合起来,...所以添一层描述对象来解决这个问题,测试case中可以简单比较描述对象,实际起作用的Promise由redux-saga内部生成 这样做的好处是单测中不用mock异步方法(一般单测中会把所有异步方法替换掉...),这不很过分 注意,不需要mock异步函数只是简化了单元测试的一个环节,即便使用这种对比描述对象的方式,仍然需要提供预期的数据,例如: // 测试场景直接执行 const iterator = fetchProducts...区别是Flux用action描述消息(发生了什么),而redux-saga用Effect描述操作指令(要做什么) Effect creator redux-saga/effects提供了很多用来生成Effect...术语Saga指的是一系列操作的集合,是个运行时的抽象概念 redux-saga里的Saga形式上是generator,用来描述一组操作,而generator是个具体的静态概念 P.S.redux-saga

1.9K41

React 16 - 生态:UI 库、Next.js、测试、开发调试工具

React 组件 页面也是标准的 node 模块,可以使用其他 React 组件 页面会针对性打包,仅包含其引入的组件 使用 Link 实现同构路由 使用 next/link 定义链接 点击链接时页面不会刷新...使用 prefetch 预加载目标资源 使用 replace 属性替换路由 动态加载页面 import dynamic from 'next/dynamic'; const DynamicComponentWithCustomLoading...React 让前端单元测试变得容易 React 应用很少需要访问浏览器 API 虚拟 DOM 可以在 Node.js 环境运行和测试 Redux 隔离了状态管理,可以进行纯数据层单元测试 # 相关工具...Jest:单元测试框架 JS DOM:浏览器环境的 Node.js 模拟 Enzyme:React 组件渲染和测试 nock:模拟 HTTP 请求 sinon函数模拟和调用跟踪 istanbul:单元测试覆盖率...# 开发调试工具 ESLint Prettier React DevTool Redux DevTool

1.5K30

更可靠的 React 组件:提纯

; // => null 即便是使用了同样的参数 'Hello World!',两次的调用返回值也是不同的。就是因为非纯函数依赖了全局状态: 变量 said。...全局变量可以作为可变(mutable)对象使用,也可以当成不可变的只读对象。 改变全局变量会造成组件的不可控行为。...纯组件 的单元测试非常简单。测试只做了一件事:检验组件是否针对给定的输入渲染出期望的输出。不需要引入、访问或修改全局变量,也没有什么摸不准的副作用了。...当请求完成后,"FETCH_SUCCESS" action 会被分发: import { call, put, takeEvery } from 'redux-saga/effects'; export...store 和 sagas 的初始化过程在此被省略了) 即便考虑到使用Redux 后需要额外的构造器,如 actions、 reducers 和 sagas,这仍然将

1K10

前端测试驱动开发模式(TDD)快速入门

) const assert = chai.assert // 从chai中引出assert 复制代码 如何实施TDD 如何写一个单元测试 首先我们看一个简单的单元测试代码: describe('测试navigateTo...如何写多个单元测试代码: 直接在describe中加入多个it函数即可: describe('测试navigateTo方法',()=>{ it(`new router 后存在navigateTo...(badFn, 'this.commonDirectFn is not a function') // 再把包装后的函数传入throws }) 复制代码 使用sinon模拟函数 如果需要模拟一个函数...,可以用sinon去模拟,使用方法:sinon.fake(),并且课已通过这个sinon的called方法判断函数是否被执行。...let fn = sinon.fake() //生成一个模拟函数 assert(fn.called) //断言这个函数是否被执行 复制代码 小结 本文只是对Tdd的一个简单介绍,适用于快速入门。

2.4K20

提高代码质量——使用Jest和Sinon给已有的代码添加单元测试

现在,我们可以使用单元测试来提高自己的代码质量。下面,我将自己在使用Jest和Sinon.js配置和编写单元测试中的收获的经验和踩到的坑进行总结,根据从零开始配置和编写单元测试这一条线来进行分享。...通过本文,你可以解决以下问题: Jest与Sinon.js是什么? 如何配置Jest与Sinon.js,从而编写单元测试如何解决进行单元测试中遇到的常见问题?...如何配置Jest与Sinon.js,从而编写单元测试?...编写单元测试 在本章中,我们会针对如何编写单元测试文件进行一个具体的讲解,其中包含: 同步函数测试 异步函数测试 HTTP测试 同时,我们会对当中使用到的Jest和Sinon.js的API会进行简单介绍...在本章中,我们总结了如下问题来进行介绍,希望大家再遇到相同问题时能够快速解决: 如何统计Jest单元测试覆盖率 如何设置单元测试文件不使用本地的babel配置 如何设置单元测试文件使用本地的babel配置

3.7K00

Redux:从action到saga

但是当需要处理异步的action(在函数式编程里称为副作用)的时候事情就没有这么简单了。为了解决这个问题,redux建议使用中间件(尤其是thunk)。...基本上,如果你需要出发副作用(side effects),使用一种特定的action生成方法:一种返回一个方法的方法,可以实现任意的异步访问并分发任意你想要的action。...使用这个方式会很快导致action生成方法变得复杂并难以测试。这个时候就需要redux-saga了。在redux-sagasaga就是一个可声明的组织良好的副作用实现方式(超时,API调用等等。。)...我们来看看如何写一个action creator来获取后端数据并分发到redux store。...所以,我们来看看如何redux应用里添加saga

1.2K00

React-Redux-Saga

Redux-saga 简介redux-sagaredux-thunk 一样, 是一个 Redux 中获取存储异步数据的中间件redux-saga 可以直接拦截 dispatch 派发的 action..., 从而实现在执行 reducer 之前执行一些其它操作使用 Redux-saga安装 Redux-saganpm install redux-saga在创建 store 时应用 redux-saga...undefined);export default store;我们可以利用传入的生成器告诉 redux-saga, 需要拦截哪些 dispatch 派发的 action,声明一下,至于什么是生成器可去查看一下博主...JS 流程框架与特性 的标签里面会进行介绍什么是生成器,然后这个陌生的问题就过,我们继续,创建 saga.js 在当中定义生成器代码,在生成函数中获取网络数据:import {takeEvery,...,添加到 Redux 中保存是通过 Saga 提供的 put 方法进行添加即可,在更改 store.js 告诉 saga 中间件的生成器哪些通过 dispatch 派发的 action 需要进行拦截,

18030

一天梳理完react面试高频题

(1)使用react-thunk中间件redux-thunk优点:体积⼩: redux-thunk的实现⽅式很简单,只有不到20⾏代码使⽤简单: redux-thunk没有引⼊像redux-saga或者.../** 发送get请求,并生成相应action,更新store的函数 @param url {string} 请求地址 @param func {function} 真正需要生成的action对应的...action时,该action的函数体会自动执行 store.dispatch(action)}(2)使用redux-saga中间件redux-saga优点:异步解耦: 异步操作被被转移到单独 saga.js...实现,代码异常/请求失败 都可以直接通过 try/catch 语法直接捕获处理功能强⼤: redux-saga提供了⼤量的Saga 辅助函数和Effect 创建器供开发者使⽤,开发者⽆须封装或者简单封装即可使...⽤到,但是我们依然需要引⼊这些代码ts⽀持不友好: yield⽆法返回TS类型redux-saga可以捕获action,然后执行一个函数,那么可以把异步代码放在这个函数中,使用步骤如下:配置中间件import

4.1K20

Taro 小程序开发大型实战(六):尝鲜微信小程序云(上篇)

存储:支持文本、图片等用户生成内容的存储,可以获取资源的链接进行使用。...敬请期待哦✌️~ 实战 Redux 异步工作流 安装 我们使用 redux-saga 这个中间件来接管 Redux 异步工作流的处理异步请求部分,首先在项目根目录下安装 redux-saga 包: $...配置 redux-saga 中间件 安装完之后,我们接着要先配置 redux-saga 才能使用它,打开 src/store/index.js 文件,对其中的内容作出对应的修改如下: import {...在循环内部,我们使用redux-saga 提供的 effects helper 函数:take,它用于监听 LOGIN action,获取 action 中携带的数据。...注意 对生成函数不了解的同学可以看一下这篇文档:迭代器和生成器[13]。

2.2K20

高级前端react面试题总结

Redux 请求中间件如何处理并发使用redux-Saga redux-saga是一个管理redux应用异步操作的中间件,用于代替 redux-thunk 的。...redux-saga如何处理并发:takeEvery可以让多个 saga 任务并行被 fork 执行。.../** 发送get请求,并生成相应action,更新store的函数 @param url {string} 请求地址 @param func {function} 真正需要生成的action对应的...action时,该action的函数体会自动执行 store.dispatch(action)}(2)使用redux-saga中间件redux-saga优点:异步解耦: 异步操作被被转移到单独 saga.js...⽤到,但是我们依然需要引⼊这些代码ts⽀持不友好: yield⽆法返回TS类型redux-saga可以捕获action,然后执行一个函数,那么可以把异步代码放在这个函数中,使用步骤如下:配置中间件import

4.1K40

如何自动化测试 React Native 项目 (下篇) - 单元测试

接着上篇的内容, 这篇文章会详细的介绍在 Glow 我们如何单元测试, 以及在 React Native 中各个模块单元测试的详细实现方式。...相比其他单元测试:karma (test runner) + mocha(test framework) + chai (assertion) + sinon (test spy) + ......Jest Snapshot Test的特点: Jest 使用一个 test renderer 来生成出 React tree 的序列化结构树。...如果你的项目有难以测试的函数/组件, 应该先想着如何refactor,把庞大复杂的逻辑/组件拆分成功能单一的单元, 尽量让一个函数只做一个task。...selector 是可嵌套的, 但只要正确的 mock redux state, 最终的结果就应该是唯一的。 4. Utils 测试 和普通的js函数单元测试没有区别,就不多赘述了。

3.2K21
领券