首页
学习
活动
专区
圈层
工具
发布

从echarts-for-react源码中学习如何写单元测试

前言 如果你熟悉React和Echarts的话,应该有用到过 echarts-for-react(虽然它现在没有维护了),本文就通过它写的测试用例来学习下如何写单元测试 如何测试function 有如下函数...() 作用: 把遇到的计时器挂起,在必要时,再使用jest.runOnlyPendingTimers执行掉已经挂起的计时器 这里使用jest.useFakeTimers()的目的就是暂停正在执行的timer...('echarts-for-react echarts-for-react-root'); // style // 获取最外层节点,判断height是否为 300px expect...).toBeCalled(),判断函数有被调用 ④ 通过component.setProps(),来为组件传入新属性 ⑤ 通过component.update()来强制更新React组件,如果组件是ClassComponent...props ⑨ jest.fn()的作用 ⑩ 如何测试组件已卸载 源码地址(有改动) https://github.com/AttackXiaoJinJin/echarts-for-react/tree

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

    使用Enzyme测试React(Native)组件|洞见

    ,其中设置了displayName并且它的第一个字符为大写字母,就能通过字符串找到它,与此同时也可以基于React组件属性的子集来查找组件和节点。...前面我们所谈论的都是如何测试使用react-dom所构建的React组件,即最终渲染的结果是浏览器当中的DOM结构,但对于React Native来说,JavaScript代码最终会被编译并用于调用iOS...事实上,我们可以通过欺骗React Native让它返回常规的React组件而不是Native组件,然后就又能愉快地使用传统的JavaScript测试库来单独测试React Native组件逻辑。...react-native-mock这个辅助库,这是一个使用纯JavaScript将全部的React Native组件进行mock的第三方库,只需要导入这个库就可以对React Native组件进行渲染和测试...总结 上一期技术雷达中指出:我们非常享受Enzyme为React.js应用提供的快速组件级UI测试功能。

    2.8K40

    Jest与React Testing Library:前端测试的最佳实践

    Jest 和 React Testing Library (RTL) 是前端开发中用于测试 React 应用的首选工具。...Jest 是一个功能丰富的JavaScript测试框架,而React Testing Library 是一种提倡以用户角度编写测试的库,它鼓励测试组件的行为而不是内部实现细节。...测试组件的交互性React Testing Library 强调测试组件的行为,而不是它的实现细节。...;测试组件的边缘情况确保覆盖组件的所有边缘情况,包括空值、异常数据和边界条件:it('displays loading state when data is fetching', () => { render...选择性运行测试使用--findRelatedTests选项只运行与更改相关的测试,以加快测试速度:npx jest --findRelatedTests使用快照测试对于不经常更改的组件,使用快照测试可以节省时间

    1.1K00

    如何测试 React 异步组件?

    前言 本文承接上文 如何测试驱动开发 React 组件?,这次我将继续使用 @testing-library/react 来测试我们的 React 应用,并简要简要说明如何测试异步组件。...,若在生产环境中,我推荐使用 react-hook-form 测试提交 接下来测试下 onSubmit 方法必须包含 username 和 password, 我们需要模拟用户输入,这个时候我们需要安装...相信经过登录的测试,我们在来写博客列表的测试已经不难了,我们先来写下测试用例: 接口请求中页面显示 loading 请求成功显示博客列表 列表为空显示暂无数据 请求失败显示服务端错误 博客列表代码 下面的代码中...,通过 toHaveBeenCalledWith 测试调用方法的参数,虽然这边是空数据,但是我们也可以写,确保调用参数是空。...: 通过 mock 使组件可以获取静态假数据; 测试加载状态; 测试异步方法是否被正确调用,并且带上了正确的参数; 测试组件是否正确地渲染了数据 测试异步方法错误时,组件是是否渲染了正确的状态 文中关于登录成功后页面跳转并未测试

    4K50

    JavaScript测试教程-part 2:引入 Enzyme 并测试 React 组件

    JavaScript测试教程-part 1:用 Jest 进行单元测试 2. JavaScript测试教程–part 2:引入 Enzyme 并测试 React 组件 3....JavaScript测试教程–part 4:模拟 API 调用和模拟 React 组件交互 在本教程的第一篇中,我们简要介绍了单元测试的基础。这次要更进一步,使用 Enzyme 库测试 React。...我们在这里用了 Jest,不过 Enzyme 也可以与 Mocha 和 Chai 之类的库一起使用。 Enzyme 基础 Enzyme 是一个库,用于在测试时处理你的 React 组件。...,如果提供的任务列表为空,将会发生什么,如果包含任务,又会发生什么。...总结 本文中我们已经了解了使用 Enzyme 测试 React 组件的基本知识。我们已经介绍了安装 Enzyme 并运行第一个简单测试。使用的渲染类型称为“浅渲染”。

    1.6K50

    ECharts 迎来重大更新,运行时包体积可减少 98%!

    ,开发者可以方便地实现多级数据的动画效果; 为饼图和极坐标系图表增加了更多配置项,可以实现更丰富的样式; 新增阿拉伯语和荷兰语两种语言的翻译 …… 接下来我们会具体介绍这些新功能,新的一年让我们一起学习使用更强大的...增强的 ESM 支持 为了让开发者在测试和 Node.js 环境使用更方便,我们在这个版本中对 ESM 的识别问题进行了优化。...虽然这在 bundlers 环境表现良好,但 Node.js 环境和一些基于 Node.js 的测试框架(如 vitest 和 jest)中的表现并不理想。...、jest 和 create-react-app 这样的环境中解析为 ESM。...我们还确保了这个新功能与各种环境兼容,包括运行时(Node.js/vitest/jest(create-react-app)/ssr/…)和打包器(webpack/rollup/vite/esbuild

    1.3K10

    web前端好帮手 - Jest单元测试工具

    当url中参数为空时 获取url参数返回值经过decode Webstorm测试界面能看到清晰的分组: ?...所以推荐大家用.toMatchSnapshot([快照名称])给快照设置命名,在差异对比就能一眼看出是哪句测试代码出问题了,也不会有维护的问题。 React组件如何覆盖测试?...首先安装react-test-renderer库,该库支持将React组件渲染为纯JS对象: npm install -D react-test-renderer 举个简单的例子: const renderer...= require("react-test-renderer"); test("测试React组件渲染", () => { let renderInstance = renderer.create(...注意,如果redux状态组件测试时,要先初始化store和触发redux的事件后,再渲染React组件: test("init", () => { let store = initStore(combineReducers

    5.7K40

    如何测试自定义Hooks的正确性?

    测试自定义 Hooks 的正确性需要验证其在不同场景下的行为是否符合预期。由于 Hooks 依赖 React 运行时环境,我们需要使用专门的工具来模拟 React 组件环境进行测试。...以下是常用的测试方法和示例:一、测试工具选择测试框架:Jest(提供断言、 mocking 等功能)React 测试工具:React Testing Library(提供渲染组件和用户交互的 API)专门的...Hooks 测试工具:@testing-library/react-hooks(简化 Hooks 测试,无需手动创建组件)二、测试自定义 Hooks 的核心思路测试初始状态是否正确测试状态更新逻辑是否符合预期测试副作用...(如事件监听、API 请求)是否正确执行和清理测试边界条件(如空值、错误输入)的处理三、具体测试示例1....:专注于测试输入输出和行为,而非内部变量或逻辑步骤五、总结测试自定义 Hooks 的关键是使用 @testing-library/react-hooks 提供的 renderHook 和 act 等工具

    9610

    写代码无BUG,网易云前端单元测试方案总结

    jest Jest 是 facebook 出的一个完整的单元测试技术方案,集 测试框架, 断言库, 启动器, 快照,沙箱,mock工具于一身,也是 React 官方使用的测试工具。...使用 Jest + Enzyme 对 React 进行单元测试 ?...shallow 使用 react-test-renderer 将组件渲染成内存中的对象, 可以方便进行 props, state 等数据方面的测试,对应的操作对象为 ShallowWrapper,在这种模式下仅能感知到第一层自定义子组件...mount 使用 react-dom 渲染组件,会创建真实 DOM 节点,比 shallow 相比增加了可以使用原生 API 操作 DOM 的能力,对应的操作对象为 ReactWrapper,这种模式下感知到的是一个完整的...另外测试 React组件除了 Enzyme 提供的操作, Jest 中还有很多其他有用的特性,比如可以 mock 一个 npm 组件的实现,调整 setTimeout 时钟等,真正进行单元测试时,这些工具也是必不可少的

    10.6K20

    《测试驱动的React开发:从单元验证到集成协同的深度实践》

    理解测试在React项目中的意义,需要跳出“为测试而测试”的误区。...这种“先定义后实现”的思路,能提前暴露逻辑漏洞:比如一个表单组件在不同输入场景下的反馈机制,若测试用例覆盖了空值、无效格式、超出范围等情形,开发过程中就会自然规避模糊处理的倾向。...React组件的复杂性往往源于状态管理与业务逻辑的交织,而Jest提供的模拟机制,能像外科手术般剥离外部依赖,聚焦核心逻辑的验证。...掌握这种互补性,能让测试更有针对性——用Jest测试自定义Hook的状态计算逻辑,用React Testing Library验证组件在用户操作下的渲染结果,两者结合形成完整的验证闭环。...Jest提供的异步处理机制与React Testing Library的waitFor函数,正是为解决这类问题设计,善用这些工具能大幅提升测试的稳定性。

    9400

    单元测试

    是一个用于测试 React 组件的 JavaScript 测试工具库,它提供了一组简单且易于使用的 API,可以帮助你编写可读性高、可维护性强的测试代码。...(已默认引入,不需要手动再次引入) 文件命名规则 在需要测试的目录下新建 __tests__ 目录 根据要测试的内容命名测试文件 对于组件文件,可以使用组件的名称作为文件名,并在文件名后面添加 .spec.tsx...对于层级较深的组件,需在单测文件中增加注释,说明测试组件所在的路径 运行单测 单测执行 安装 VSCode Jest 运行插件 名称: Jest Runner ID: firsttris.vscode-jest-runner...act } from '@testing-library/react'; act 是一个用于处理 React 组件的异步更新和副作用的工具函数,它的主要作用是确保在测试中正确地触发和等待组件更新。...act 的使用场景如下: 当你在测试中进行与 React 组件的交互(例如模拟用户点击、输入等)时,可以使用 act 来确保组件在更新后进行正确的断言。

    1.4K10

    用Jest来给React完成一次妙不可言的~单元测试

    需要什么样的测试 软件测试是有级别的,下面是《Google软件测试之道》一书中,对于测试认证级别的定义,摘录如下: •级别1 •使用测试覆盖率工具。•使用持续集成。•测试分级为小型、中型、大型。...技术栈选择 当我们想要为 React 应用编写单元测试的时候,官方推荐是使用 React Testing Library[1] + Jest[2] 的方式。...如果没有存储,它将创建一个新的存储,如果它没有接收初始状态或存储,它将返回一个空对象。 接下来,我们使用render()来呈现组件并将存储传递给提供者。...测试初始状态是否为0: TextContext.test.js import React from 'react' import "@testing-library/jest-dom/extend-expect...结语 React Testing Library 是用于测试 React 应用的一大利器。它为我们提供了访问 jest-dom 匹配器的机会,以及最佳实践,使得我们可以使用它来更有效地测试我们的组件。

    15.8K33

    使用storybook管理React组件

    本文已React的UI组件为例,演示如何新建/集成Storybook到项目中,并对UI组件进行全方位的管理,包括发布、demo文档、测试等。 1....以一个分页组件为例 从团队的stoneUI组件库直接移植过来 将Pagination、IconV组件源码放入components目录; 编写story: import React from 'react...测试UI组件 4.1 写测试用例的原因 找到bug 新修改没有改变已有的接口和功能 将测试用例作为文档 4.2 测试结构 使用storyshots插件来实现,其核心是使用Jest,原理是每次生成一份DOM...4.3 测试交互 storybook交互性测试可以使用 Enzyme来模拟用户输入,然后使用Mocha or Jest来进行结果测试,storybook又一个专门的插件帮助我们集成他们:specifications...,通过断言来测试UI组件的属性,更多使用方法可以参考specifications插件的使用。

    3.8K20

    对 React 组件进行单元测试

    React 单元测试中用到的工具 III. 用测试驱动 React 组件重构 IV. React 单元测试常见案例 I....React 单元测试中用到的工具 Jest 不同于"传统的"(其实也没出现几年)的 jasmine / Mocha / Chai 等前端测试框架 -- Jest的使用更简单,并且提供了更高的集成度、更丰富的功能...fs 进行预处理读写等,灵活性非常高,可以很好的兼容各种项目 babel-jest 由于是面向src目录下测试其React代码,并且还使用了ES6语法,所以项目下需要存在一个.babelrc文件: {...这个单词的伦敦读音为 ['enzaɪm],酵素或酶的意思,Airbnb 并没有给它设计一个图标,估计就是想取用它来分解 React 组件的意思吧。...对于一些组件和共有函数等,完善的测试也是一种最好的使用说明书。

    5.2K40

    react生态下jest单元测试

    一:jest框架搭建 1.在本地创建一个目录jest_practice 2.使用编辑器VScode打开目录,紧接着在终端中打开,执行npm init 图片 3.执行以下命令: 注意:这里我们使用cnpm...更新快照命令:jest --updateSnapshot 被测组件代码如下: //被测组件 import React from 'react'; const STATUS = { HOVERED...、断言或是进行 snapshot 测试 //React 组件的 render 结果是一个组件树,并且整个树最终会被解析成一个纯粹由 HTML 元素构成的树形结构 it("renders correctly...如果尝试对这些对象进行快照,它们将强制快照在每次运行时失败. //2.Jest允许为任何属性提供非对称匹配器。...如果尝试对这些对象进行快照,它们将强制快照在每次运行时失败. //2.Jest允许为任何属性提供非对称匹配器。

    2.7K20

    React 设计模式 0x8:测试

    学习如何轻松构建可伸缩的 React 应用程序:测试 # 如何测试组件 测试在每个 Web 应用程序中都非常重要,即使在 React 中也是如此,特别是在其组件方面。...# 渲染测试 渲染测试是一种测试,用于验证您的组件是否正确渲染。 # 使用 Jest 进行功能测试 Jest 是测试 React 应用程序时非常流行的测试库。...# 使用 Jest 进行集成测试 在大多数 React 应用程序中,通常需要与外部 API 集成以在应用程序中发布和获取数据。 可以使用 Jest 来测试 API 行为,以查看预期和意外结果。...# React 测试最佳实践 对每个组件编写测试 为每个组件编写测试,以确保它们能够正确地渲染和响应 使用测试库 使用 Jest 和 React Testing Library 等测试库,它们提供了专门用于测试...React 组件的工具和函数 编写测试用例 编写完整的测试用例,覆盖组件的所有代码路径,包括正常情况和异常情况 使用快照测试 使用 Jest 中的快照测试功能来验证组件是否按预期呈现 使用模拟数据

    2.4K10

    React 组件测试技巧

    React 组件的常见测试模式。 注意: 此页面假设你正在使用 Jest 作为测试运行器。如果你使用不同的测试运行器,你可能需要调整 API,但整体的解决方案是相同的。...在测试环境页面阅读更多关于设置测试环境的细节。 在这个页面上,我们将主要使用函数组件。然而,这些测试策略并不依赖于实现细节,它对于 class 组件也同样有效。...注意: React 测试库为触发事件提供了一个更简洁的助手。 --- 计时器 {#timers} 你的代码可能会使用基于计时器的函数(如 setTimeout)来安排将来更多的工作。...的计时器 mock 为这个组件编写测试,并测试它可能处于的不同状态。...例如,你可能正在使用 react-test-renderer 组件上运行快照测试,该组件内部使用子组件内部的 ReactDOM.render 渲染一些内容。

    5.3K00

    用 jest 单元测试改善老旧的 Backbone.js 项目

    通常的 Backbone 项目也可以忽略文中涉及 react 的部分。 升级测试框架 和之前文章中的例子相同,本次依然采用 Jest 作为测试框架。...的单元测试并不严谨,依赖了提供 mock 数据的 php 服务器环境 三是由于视图层没有很好的组件化,从而缺乏对视图组件的测试 jest for Backbone 的实践 jest 是比较新的测试框架...这一方面是囿于当时测试意识的不足,更主要的原因是没能很好解决组件化的问题。 要对 view 进行测试,就得将其拆分重构为功能明确、便于复用的各种小型组件。...: it("应该在不显示门店时渲染为空", function() { const ViewClass1 = CardShops({}); const comp1 = (new ViewClass1...:页面或组件中一般会用 text.js 组件引入模板,其 ES6 形式为: import cardTmpl from 'text!

    4K10
    领券