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

「前端架构」Grab的前端学习指南

ES2015使用较多的特性包括“箭头和词法This”、“”、“模板字符串”、“析构”、“缺省/Rest/Spread操作符”和“导入和导出模块”。 预计持续时间:3-4天。...开发经验——开发过程,我们花了很多精力来创建工具来帮助调试和检查应用程序,比如Redux DevTools。 您的应用程序可能必须处理异步调用,如发出远程API请求。...Jest可以保存React组件和Redux状态生成的输出,并将其保存为序列化文件,这样您就不必自己手动生成预期的输出。Jest还具有内置的模拟、断言和测试覆盖率。一个图书馆来统治他们所有人!...React附带了一些测试工具,但是通过类似于jquery的API,通过Airbnb提供的可以更容易地生成、断言、操作和遍历React组件的输出。建议用测定反应组分。...Jest使编写前端测试变得有趣和容易。因为定义了明确的职责和接口,所以React组件和Redux操作/缩减器相对容易测试也很有帮助。

7.4K20

干货 | 携程租车React Native单元测试实践

1.2 Enzyme Enzyme是AirBnb开源的React测试工具库,通过一套简洁的api,可以渲染一个或多个组件,查找元素,模拟元素交互(如点击,触摸),通过和Jest相互配合可以提供完整的..."redux-mock-store": "^1.5.3" //Redux测试模拟store } 根目录下添加jest.config.js文件作为配置文件: module.exports...七、Jest 异步测试 Jest单元测试是同步的,因此面对异步操作如fetch获取数据,需要进行异步的模拟测试。..._onClear).toBeCalled();//测试组件实例上的方法是否被调用 九、Redux测试 使用React或者React Native时通常会使用Redux进行状态的管理,需要mock store...携程租车前端单元测试的实践,我们总结出几个要点: 将待测试的组件当成黑盒,不用考虑内部逻辑实现; UI改动频繁,优先保证公用组件,工具函数,核心代码的单元测试模拟数据尽量真实; 多考虑边界条件情况

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

2021年React学习路线图

它用在函数组件,允许开发者不使用的情况下,使用状态和其他特性。 之前,函数组件是无状态的,状态和生命周期用在组件。有了 Hooks,开发者可以函数组件中使用状态。...它比 Redux 容易多,也可以使用 Hooks(现在你应该熟悉它了)。 它使获取数据变得简单,可以实际应用做一些尝试。...https://www.valentinog.com/blog/redux/ Redux Thunk 是一个流行的库,经常与 Redux 一起使用。它允许操作创建者返回函数而不是操作对象。...学习 React 它是可选的,但仍然是一个好用的库。 3.2 测试 Jest - 简单的 JavaScript 测试框架。 Jest 是一个简单的 JavaScript 测试框架,它注重简单性。...编写测试很重要,根据我的经验,通常比编写实际代码更难。 您应该学习最流行的测试库,如 Jest 和 Enzyme,以及如何使用库(如 Sinon )模拟 API 调用

7.4K21

前端食堂技术周刊第 34 期:Node.js v18 、Nuxt 3 RC1、Parcel v2.5.0、计算机程序的构造和解释

你可以通过官方发布的这篇博客来了解下面这些强大的功能: Vue3 和 TypeScript 同时支持 Vite 和 Webpack,默认使用 Vite Nitro & UnJS 文件系统自动化(Pages...Mitosis 入门快速指南[8] Mitosis 是一个编译时框架,允许你 JSX 编写组件并编译为原生 JavaScript、Angular、React、Vue 等。...Jest 基础知识 使用 Enzyme 测试 React 组件 组件 Props 测试、mount 函数渲染、快照测试 Mock 模拟 API 调用模拟 React 组件交互 使用 react-hooks-testing-library...测试 Hooks 使用 Cypress 进行端到端测试(E2E) 对比 React Testing Library 和 Enzyme 使用 Jest 和 React Testing Library 的...Toolkit: https://redux.js.org/introduction/why-rtk-is-redux-today [10] JavaScript 测试教程: https://wanago.io

1.1K20

聊一聊 2024 年 React 生态系统

目前,实用优先的 CSS(如Tailwind CSS)是主流趋势。如果希望 React 根据条件应用样式,可以考虑使用像 clsx 这样的实用库。...动画 Web 应用,所有动画都始于 CSS。但随着需求的发展,CSS 动画可能无法满足需求。这时,开发人员通常会寻求动画库的帮助,它使你能够使用 React 组件进行动画操作。...测试 测试 React 应用的核心是使用如 Jest 这样的测试框架。Jest 提供了测试运行器、断言库以及其他实用的功能,满足全面测试框架的需求。...如果倾向于使用 Vite,Vitest 是一个值得考虑的 Jest 替代方案。 测试框架渲染 React 组件时,可以使用 react-test-renderer。...它能够渲染组件并模拟HTML元素上的事件。然后,可以使用测试框架进行断言。 如果正在寻找用于 React 端到端(E2E)测试测试工具,Playwright 和 Cypress 是最受欢迎的选择。

52410

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

vuejs 测试可以用 vue-test-utils) Enzyme 提供了可以直接操作 React component 的 props 和s tate 的方法,使得建造测试 context...; state(), props()进行数据查找; setState(), setProps()进行数据操作; simulate()模拟时间触发。...交互测试,我们主要利用 simulate() API模拟事件,来判断这个元素的 prop 上的特定函数是否被调用, 传参是否正确, 以及组件状态是否发生意料之中的修改。...WWW API测试 WWW API测试是指对server接口的测试, 只要在测试代码调用 React Native 的API模块的方法并且验证返回结果的正确性即可(可能需要 mock 一些 token...测试 server 的时候和正常的 WWW API 测试类似, 只要保证发送的请求(同样需要 mock header 并正确的调用 setContext 来设置 graphql 请求的参数) server

3.2K21

React + Redux Testing Library 单元测试

同一个文件夹创建一个 math.test.js 文件,在这里我们将使用 Jest测试 math.js 定义的函数: image.png 然后运行 yarn test (添加 NPM Script...唯一需要注意的是, 额外的expect.assertions(number) 其实是验证测试期间所调用的断言数量,这在测试多层异步代码时很有用,以确保实际调用回调的断言次数。...从技术上讲,你可以真实的浏览器运行,但由于不同平台上启动真实浏览器的复杂性,更建议使用 JSDOM 虚拟浏览器环境运行 Node 测试。...当测试 action 的时候,我们需要增加一个 mocking 服务层——例如,我们可以把 API 调用抽象成服务,然后测试文件中用 mock 服务响应所期望的 API 调用。...然后我们就可以使用 Jest 模拟一个 action 的行为再传给 store,而 actionClick 这个伪造函数能够让我们去断言该 action 是否被调用过。

2.3K10

Vue 应用单元测试的策略与实践 04 - Vuex 单元测试

本文的目标 2.2 Vue 应用的单元测试,对 Vuex store 该如何测试?如何测试与 Vue 组件之间的交互? // Given 一个有基本的UT知识和Vue组件单元测试经验的开发者?...而一个较为复杂、具备测试价值的 mutation 保存数据的同时,还可能进行了合并、去重等操作。...Action 应对起来略微棘手,因为它们可能需要调用外部的 API。...当测试 action 的时候,我们需要增加一个 mocking 服务层——例如,我们可以把 API 调用抽象成服务,然后测试文件中用 mock 服务响应所期望的 API 调用。...然后我们就可以使用 Jest 模拟一个 action 的行为再传给 store,而 actionClick 这个伪造函数能够让我们去断言该 action 是否被调用过。

1.6K30

Jest单元测试之旅—实践总结

在过程化编程,一个单元就是单个程序、函数、过程等;对于面向对象编程,最小单元就是方法,包括基(超)、抽象、或者派生(子类)的方法。...之后文中的每一组测试均可在源码中找到 单元测试实践 一、常用API 开始正式的代码测试前,我们先认识一下常用的基础Jest API内容。...这意味着模块模拟不会包装原始模块,它会完全替换require系统的原始模块。因此,mockRestore可以模拟模块模拟函数上定义,但是调用它不会恢复原始实现。...如果我们测试用例中直接访问window.bridage.callPhone时,会提示Cannot read properties of undefined,因为jsdom并没有对应的api实现,所以我们需要在测试前构造一个模拟的方法...我们可以使用private对方法进行私有化,此时我们单测时没办法直接访问或者模拟。需要通过对私有成员使用数组访问或者通过prototype属性进行模拟

10.2K20

【送红宝书】JavaScript 测试系列实战(四):掌握 React Hooks 测试技巧

之前 useModalManagement 钩子的测试代码,我们仅仅只测试调用 Hook 时不会报错。...false(关闭状态) 测试打开模态框:这个测试的难点在于怎么去触发 openModal ,所幸 react-hooks-testing-library 提供了 act 工具函数来模拟浏览器 Hook...的工作方式;act 函数同样接受一个函数执行一系列同步操作 注意 如果不使用 act 函数,而是直接将操作写在用例Jest 会抛出警告,并且可能会遇到一些棘手的边界情况。...测试异步钩子 刚才的 useModalManagement 涉及到的都是同步操作,然而在实际应用,很多钩子都涉及到异步操作,例如 API 数据获取等。那么我们该怎么测试这些异步钩子呢?...至于怎么用 Mock 来写,就留给作业给你吧~ 测试 Redux + Hooks 规模较大的应用,我们通常会使用一个状态管理库来解决复杂的数据流问题,而最受欢迎的选择无疑是 Redux

2.1K00

年轻时,我不写单元测试

一个多人协作的大型项目中,我们开发的过程可能经常会面临到这样的问题: 哎,这次我没有改动到这里啊,这怎么会有bug呢 哎,怎么新加了个功能原来的功能受影响了呢 哎,这里的样式为什么乱掉了 当我们被提出这些...但是仔细想想,这其实就违背了我们单元测试的初衷,笔者这里也大胆猜测下,jest官方实现这个功能的时候,应该也只是想记录下一步一步的事件后,当前组件的html结构,对比上一次的快照,来看功能是否符合预期...一开始我觉得单元测试很鸡肋的原因也是没有深入了解它,这次发现就算是和业务结合很紧密的组件,也能够模拟正常的操作,这里就贴一个和redux结合的组件来举例 import React from 'react...那其实整个流程就是初始化这个组件,看看渲染的html结构是否符合预期,然后点击下拉框,选中其中第一个,发起请求,拉回详细数据,再观察组件是否展示正常,编写完测试用例后,就已经用代码模拟了整个手工操作,怎么样...更新一个bug fix,高阶组件下,我们需要调用wrapper.update(); 这里是issue 更新一个jest全局变量包

84820

单元测试

交互),推荐单测之前已评审过测试用例 公共 公共组件 公共方法 公共自定义hook 需求功能 组件的Props(组件的入参是否正确的场景或时机被正确的使用或调用) Render 交互(基于用户的交互判断关键节点的流程是否正确的时机被正确执行...它提供了一组简单易用的 API,可以模拟用户浏览器的各种交互行为,如点击、输入、选择等,用于帮助开发者编写更全面、准确的测试用例。...jest-location-mock 用于 Jest 测试模拟浏览器window.location对象的库。...它的主要作用是使你能够测试代码模拟修改和访问window.location的行为,而无需实际浏览器环境执行。...(已默认引入,不需要手动再次引入) jest-canvas-mock 用于测试环境模拟 HTML5 Canvas。

15910

2016 JavaScript 技术栈展望

Redux ,大多数的组件都是纯函数式的组件,也只有一个集中的存储和资源中心。Redux 的实例方法负责整个数据的操作和维护。相比 Flux 来说,Redux 的思路更加清晰。...常见的测试工具有 Jasmine、Mocha、Tape、Ava、Jest 等,它们各有所长。...我对一个测试框架的要求有如下几条: 可以浏览器运行,便于调试 执行速度快 便于处理异步测试 便于命令行中使用 可以兼容任意断言和数据模拟的第三方库 第一条标准就排除了 Ava 和 Jest。...我不认为上述有一个完美的解决方案,但我对 API 有一个自己的认知: 可预测,遵循一致性协议 支持一次查询获取多个实体 支持更新操作 易于调试 易于使用 到目前为止,我还没有发现满足上述所有条件的解决方案...本质上,Electron 内部封装了一个 Node.js,可以打开 Chrome 窗口渲染 UI,还可以访问操作系统本地的 API,并且没有浏览器的沙盒机制。

2K40

开发 | 效率提升 100%,小程序开发应该这样做

如果众多的异步操作都直接在 App 或 Page 中一一实现,相信开发起来会很困难,而且不易于测试。...因此,我又因此针对微信小程序实现了一个基于 Redux 方案的状态管理模块,用以方便地小程序实现应用状态管理 redux-weapp。...接下来,我们来安装 Redux: 需要注意的是,由于实际应用,我们经常会需要异步调用 API 服务器的接口,因此我们还需要 redux-thunk 这个模块,来处理异步行为。...定义 npm 命令 首先是代码测试命令 test。 由于我喜欢用 Jest,所以这里也用 Jest 做范例。 接下来,就是激动人心的 build 命令。...借助上述的 weapp 和 redux-weapp,希望你开发小程序的时候,会感到很舒服。 在这个范例,我们目标是去查询 GitHub 和 Octokit 的开源项目,并显示小程序

89130

前端自动化测试

React项目测试选型 react-addons-test-utils:官方API,有些晦涩 Enzyme:源自Airbnb,封装了React官方测试APIJquery风格简洁的API, 使得Dom...操作变得十分友好 综合目前市面上的轮子,我们技术选型为Jest+Enzyme 实践 例子是一个基于Antd二次封装的单选年的日期选择器,如下演示: 图片 代码结构如下 图片 其中测试相关的文件,...test,后缀名为xxx.test.js的文件,在运行测试时会自动执行,snapshots为自动生成的页面快照。...这里可以首先简单的看一下,Jest+Enzyme的基本语法: JestAPI更多着力于定义测试、断言、mock库 定义测试: describe: 定义一个测试套件(test suite) it: 定义一个测试...测试默认值,即检查输入框的值是否为默认值 测试清除按钮是否可用,通过模拟点击清除按钮,测试是否能按照预期清除输入框内填充的默认值 测试设置值,点击输入框,弹出选择框,选择值,检查输入框的值是否为选择的值

1.9K20
领券