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

JavaScript测试教程–part 4:模拟 API 调用和模拟 React 组件交互

JavaScript测试教程–part 4:模拟 API 调用和模拟 React 组件交互 今天,我们进一步测试 React 组件。它涉及模拟组件交互和模拟 API 调用。你将学到两种方法,开始吧!...).toBeCalled(); }); }); }); 通过调用 jest.mock('axios'),Jest 在的测试和组件中都用我们的模拟代替了 axios。...spyOn 函数返回一个 mock函数。有关其功能的完整列表,请阅读文档。我们的测试检查组件在渲染和运行之后是否从模拟中调用 get函数,并成功执行。...它是前面提到过的 ShallowWrapper 的功能。我们用它来模拟事件。第一个参数是事件的类型(由于在输入中使用了 onChange,因此在这里应该用 change),第二个参数是模拟事件对象。...从测试中返回 promise 是能够确保 Jest 等待其解决的一种方法。 总结 在本文中,我们介绍了模拟模块,并将其用于伪造 API 调用。由于没有发出实际的请求要求,我们的测试可以更可靠、更快。

3.7K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    JavaScript 测试系列实战(三):使用 Mock 模拟模块并处理组件交互

    axios 模块提供了一个 get 函数,并且会返回一个 Promise,包含预先设定的假数据。...打开 TodoList 的测试文件,首先在最前面通过 jest.mock 配置 axios 模块的 Mock(确保要在 import TodoList 之前),在 Mock 之后,无论在测试还是组件中使用的都将是...它第一个参数是事件的类型(由于我们在输入中使用onChange,因此我们应该在此处使用change),第二个参数是模拟事件对象(event)。...postSpy.mock.results 是 post 函数发送结果的数组,通过使用它,我们可以得到返回的 promise,我们可以从 value 属性中取到这个 promise。...从测试返回 promise 是确保 Jest 等待其异步方法执行结束的一种方法。 小结 在本文中,我们介绍了 mock 模块,并将其用于伪造API调用。

    4.8K20

    那些年错过的React组件单元测试(上)

    可以使用.promises/.rejects对返回的值进行获取,或者使用then/catch方法进行判断。...在单元测试中,我们可能并不需要关心内部调用的方法的执行过程和结果,只想知道它是否被正确调用即可,甚至会指定该函数的返回值。这个时候,mock的意义就很大了。...jest.mock('axios'),我们让jest去对axios做模拟,这样就不会去请求真正的数据了。...然后调用axios.get的时候,不会真实的请求这个接口,而是会以我们写的{ data: ['Cosen','森林','柯森'] }去模拟请求成功后的结果。...这种方式就不用去模拟axios,而是直接走的本地的模拟方法,也是比较常用的一种方式,这里就不展开说明了。

    5K20

    【干货分享】微信小程序单元测试攻略

    2,被测代码包含复杂的环境因素需要处理或模拟,例如使用了storage、调用了接口、使用了环境变量等。 (图片来源:码农翻身公众号) 但无论如何,有价值的东西就应该去做,不应该知难而退嘛。...该方法和sinon.spy一样,生成函数的“间谍”,可以断言该函数的已调用次数、调用入参、调用返回等是否符合预期。...axios.get('/api').then(res => res.data)} // 测试代码B import axios from 'axios';jest.mock('axios'); // 模拟一次接收到的数据...` }, //API 参数 { data: {} } //API 返回结果); 模拟storage调用示例2: const mockStorage = { get: jest.fn...()的返回结果,当组件中需要使用全局数据时,可通过该方式进行mock: const extendAppData = require("..

    2.8K40

    Jest中Mock网络请求

    描述 文中提到的示例全部在 jest-axios-mock-server仓库 中,直接使用包管理器安装就可以启动示例,例如通过yarn安装: $ yarn install 在package.json中指定了一些命令...npm run test:demo3: 使用Jest中的库完成demo2的实现。...使用了JSDOM模拟的浏览器环境,在jest.config.js中配置的setupFiles属性中配置了启动文件test/config/setup.js,在此处初始化了JSDOM。...mock后的对象,也就是说我们可以认为这个库已经重写了,重写之后的方法都是JEST的Mock Functions了,可以使用诸如mockReturnValue一类的函数进行数据模拟,关于Mock Functions...在这里就使用到了jest-axios-mock-server库,首先我们需要指定三个文件,分别对应每个单元测试文件启动前执行,Jest测试启动前执行,与Jest测试完成后执行的三个生命周期进行的操作,分别是

    3.4K30

    Jest中Mock网络请求

    描述# 文中提到的示例全部在 jest-axios-mock-server仓库 中,直接使用包管理器安装就可以启动示例,例如通过yarn安装: Copy$ yarn install 在package.json...npm run test:demo3: 使用Jest中的库完成demo2的实现。...使用了JSDOM模拟的浏览器环境,在jest.config.js中配置的setupFiles属性中配置了启动文件test/config/setup.js,在此处初始化了JSDOM。...mock后的对象,也就是说我们可以认为这个库已经重写了,重写之后的方法都是JEST的Mock Functions了,可以使用诸如mockReturnValue一类的函数进行数据模拟,关于Mock Functions...在这里就使用到了jest-axios-mock-server库,首先我们需要指定三个文件,分别对应每个单元测试文件启动前执行,Jest测试启动前执行,与Jest测试完成后执行的三个生命周期进行的操作,分别是

    2.6K30

    Jest实战:单元测试与服务测试

    服务为代表的,模拟用户使用环境,测试 ws 是否正常 提供测试覆盖率 针对以上问题,解决思路总结如下: 函数功能测试:断言匹配功能 请求 API:mock 模块和函数,例如测试用例中的 axios...就是被 mock 的 http 和静态服务:测试代码中启动服务后,利用 axios 等第三方请求库请求服务 websock 服务:借助 puppeteer(内置无头浏览器)来模拟用户使用,监听数据变动...配置文件和命令行 jest 提供两种方式来让用户自定义配置,一个是根目录的 jest.config.js ,另一个是启动 jest 的时候给参数。我是采用两者混搭的方法。...在做调研的时候发现,jest 的下载量和更新记录远远高于 supertest,而且更纯粹。为什么这么说呢?它提供一种测试的组织形式,其它可以借助第三方库和工具实现。...而服务测试的思路就是:在 test 目录下启动简单的 http 服务器和静态服务器,然后利用 axios 访问启动的服务器,拿到返回结果,再利用断言的写法,检查即可。

    3.4K10

    《前端那些事》从0到1开发工具库

    在日常开发中,特别是中后台管理页面,会经常使用到一些常用的函数比如:防抖节流、本地存储相关、时间格式化等,但是随着项目不断增加,复用性和通用性就成为一个很至关重要的问题,如何减少复制张贴的操作,那就是封装成为...:输入文件配置,path指的是输出路径,file是指最终输出的文件名称,最关键的是libraryTarget和library,请看下一章 2.1 webpack 关于开发类库中libraryTarget...和library属性 因为在一般SPA项目中,使用webpack无需关注这两个属性,但是如果是开发类库,那么这两个属性就是必须了解的。...做的二次封装,添加拦截器,通过拦截器统一处理所有http请求和响应。...完成工具库模块化开发之后,为了保证代码的质量,验证各模块功能完整性,我们需要对各模块进行测试后,确保功能正常使用,再进行发布 我在工具库开发使用jest作为单元测试框架,Jest 是 Facebook

    2K40

    Axios入门与源码解析

    文章出自 一、Axios的理解与使用 1. axios 是什么?...+ promise 的异步 ajax 请求库 浏览器端/node 端都可以使用 支持请求/响应拦截器 支持请求取消 请求/响应数据转换 批量发送多个请求 3. axios 常用语法 axios(config...难点语法的理解和使用 1、axios.create(config) 根据指定配置创建一个新的 axios, 也就就每个新 axios 都有自己的配置 新 axios 只是没有取消请求和批量发请求的方法...相同: (1) 都是一个能发任意请求的函数: request(config) (2) 都有发特定请求的各种方法: get()/post()/put()/delete() (3) 都有默认配置和拦截器的属性...拦截器的模拟实现 array.shift()该方法用于把数组的第一个元素从其中删除,并返回第一个元素的值 思路为先将拦截器的响应回调与请求回调都压入一个数组中,之后进行遍历运行 promise = promise.then

    3K30

    axios 二次封装-状态处理拦截器

    上篇[axios 二次封装-拦截器队列, 这篇是基于拦截器队列实现的状态处理拦截器, 某些情况下我们需要针对不同的响应状态码,执行不同的处理函数。例如: 410 权限校验, 500 服务器错误等。...这里的处理方式是,拦截器只做基础的流程控制以及接口数据统一。将状态处理转为类似form规则校验的if(){doing} 的方式,交由使用方定义具体的处理规则。...行为(act)可以简化为返回任意值的处理函数。...} export type RulesIndex = StatusCode | StatusCodeRange | StatusValidate Status 类 定义一个状态规则管理类,提供规则的管理方法和拦截器适配口...对于不同的拦截器对象,这里定义了两个适配类,提供快速注册方法 // axios export class StatusForAxios extends Status{ static create

    84620

    从 0 开始手把手带你搭建一套规范的 Vue3.x 工程化项目

    ; // 前置拦截器(发起请求之前的拦截) axios.interceptors.request.use( (response) => { /** * 根据你的项目实际情况来对...Promise.reject(error); } ); // 后置拦截器(获取到响应时的拦截) axios.interceptors.response.use( (response) => {.../** * 根据你的项目实际情况来对 response 和 error 做处理 * 这里对 response 和 error 不做任何处理,直接返回 */...安装核心依赖 我们使用 Vue 官方提供的 vue-test-utils 和社区流行的测试工具 jest 来进行 Vue 组件的单元测试。...npm i @types/jest -D TypeScript 的编译器也会提示 jest 的方法和类型找不到,我们还需把 @types/jest 添加根目录下的 ts.config.json(TypeScript

    6.6K62

    使用Typescript实现轻量级Axios

    目录 背景 搭建环境 搭建简易后台提供接口 安装原生Axios并使用 查看效果 分析传参和返回值 实现Axios createInstance 类型定义 Axios类实现GET方法 类型声明小插曲...Axios类实现POST方法 实现错误处理机制 模拟网络异常 模拟超时异常 模拟错误状态码 客户端调用超时接口 拦截器功能 使用拦截器 实现拦截器 合并配置项 实现请求与响应的转换 取消任务功能...启动客户端 yarn start 浏览器访问 http://localhost:3000/ 打开控制台查看打印结果 分析传参和返回值 查看aixos/index.d.ts文件可得知axios所需参数和返回值类型定义如下...类型定义 从分析传参和返回值的截图可得知需定义的类型 此处将源码进行简化便于理解 // axios/types.ts export type Methods = | 'GET' | 'get'...得出拦截器的规律是 请求拦截器先添加的后执行 响应拦截器先添加的先执行 使用axios.interceptors.request.eject取消指定的拦截器 // src/index.tsx axios.interceptors.request.use

    2.9K10

    Vue Ant Admin学习笔记,持续记录

    、全局的模块在这里引入(如Vue-Router),程序入口文件,初始化vue实例,并引入使用需要的插件和各种公共组件....) Mock.js 是一个模拟数据生成器,帮助前端开发和原型与后端进度分离,根据数据模板生成模拟数据,为 ajax 请求提供请求/响应模拟。...Mock.js 通过覆盖和模拟原生 XMLHttpRequest 的行为来拦截 Ajax 请求,不依赖于第三方 Ajax 工具库。 Mock.mock(),根据规则拦截请求,并返回指定的数据。...axios请求拦截器验证token是否失效,响应拦截器则是弹出错误,验证权限、退出登录,实际上就是检查token 的cookie。...7.axios拦截器和请求token token是在登录之后存到了cookie中,到期时间为json给的时间,到期之后重新登录,axios请求时用调用拦截器检测token是否过期。

    1.2K30
    领券