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

【译】使用Enzyme和React Testing Library测试React Hooks

确保代码没有bug的一种方法就是编写测试用例。测试React hooks与测试一般程序的方式没有太大区别。 在本教程中,我们将了解如何通过使用带有hooks的to-do应用程序来实现这一点。...如果你第一次使用Enzyme,我们之前发布过关于它的文章,《Enzyme如何在React应用中与Jest一起使用》。我们可以用他们来深入测试React Hooks。...这将调用removeTodo()方法,该方法将删除被单击的item。然后检查我们拥有的item的数量,并且返回的的值。 这四个测试的源代码可以在GitHub上找到。...为了模拟添加新待办项的单击事件,我们使用fireEvent.click()方法并传入getByText()方法,该方法返回的是文本与我们传的参数匹配的节点。...加油写面向对象的React代码! React钩子和应用中的其他钩子一样容易出错,你要确保你能很好地使用它们。正如我们刚才看到的,有几种方法可以做到这一点。

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

    如何测试 React 异步组件?

    前言 本文承接上文 如何测试驱动开发 React 组件?,这次我将继续使用 @testing-library/react 来测试我们的 React 应用,并简要简要说明如何测试异步组件。...,若在生产环境中,我推荐使用 react-hook-form 测试提交 接下来测试下 onSubmit 方法必须包含 username 和 password, 我们需要模拟用户输入,这个时候我们需要安装...get*By* 函数获取dom 中的元素, 这里使用 getByPlaceholderText 以上测试用例只测试了登录函数,但是我们并未写登录成功或者失败的逻辑,接下来来我们通过 jest 的 mock...然后,我们等待异步方法解析并等待 Posts 组件重新渲染。为此,我们使用 waitFor 方法,同时检查标题是否呈现,之后遍历检查,确保每一个标题在页面上。...请关注我,我会尽快出 React test 系列的下文。 希望这篇文章对大家有所帮助,也可以参考我往期的文章或者在评论区交流你的想法和心得,欢迎一起探索前端。

    3.3K50

    JavaScript 测试教程 part 1:用 Jest 进行单元测试

    首先,我将介绍单元测试的基础知识,即测试应用程序的每个部分并检查它们是否适合使用。为此我们将使用 Facebook 开发的测试框架 Jest。它已经准备就绪,并具有进行测试所需的功能。...他们将模拟滚动,单击和键入之类的行为,并从实际用户的角度检查我们的程序是否运行良好。 用 Jest 进行单元测试 Jest 是 Facebook 开发的测试框架。...package.json 1"scripts": { 2 "test": "jest" 3} 为了简单起见,我在这里将 Jest 与简单的纯 Node.js 模块一起使用(不包括 webpack)。...稍后我们将学习如何在 React 中使用 Jest 首先,让我们创建一些可以测试的简单函数。...使用 Jest,你可以使用 describe 函数对它们进行分组。它创建了一个可以合并多个测试的块。

    2.9K20

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

    技术栈选择 当我们想要为 React 应用编写单元测试的时候,官方推荐是使用 React Testing Library[1] + Jest[2] 的方式。...渲染组件可以使用 RTL's API 的 render 方法完成。签名如下: function render( ui: React.ReactElement, options?...为此,我们必须在jest.mock('axios')的帮助下模拟axios请求。 现在,我们可以使用axiosMock并对其应用get()方法。...最后,我们将使用Jest函数mockResolvedValueOnce()来传递模拟数据作为参数。 现在,对于第二个测试,我们可以单击按钮来获取数据并使用async/await来解析它。...结语 React Testing Library 是用于测试 React 应用的一大利器。它为我们提供了访问 jest-dom 匹配器的机会,以及最佳实践,使得我们可以使用它来更有效地测试我们的组件。

    15K33

    Jest:给你的 React 项目加上单元测试

    Jest 是一款轻量的 JavaScript 测试框架,它的卖点是简单好用,由 facebook 出品。本文就简单讲讲如何使用 Jest 对 React 组件进行测试。 为什么需要单元测试?...单元测试(Unit Testing),指的是对程序中的模块(最小单位)进行检查和验证。比如一个函数、一个类、一个组件,它们都是模块。 使用单元测试的优点: 更好地交付高质量代码。...Jest 基本使用 我们先写一个简单的函数,作为被测试的模块。...test 方法创建了一个测试的作用域,该方法有三个参数: 测试的描述。 我们写测试代码的函数。 测试超时时间,默认为 5 秒,有些测试是异步的,我们需要等待。...但 Jest 本身并不支持 React 组件的测试 API,需要使用另外一个内置的 React Testing Library 库来测试 React 组件。

    2.9K20

    前端单元测试之Jest

    单元测试:在计算机编程中,单元测试(英语:Unit Testing)又称为模块测试, 是针对程序模块(软件设计的最小单位)来进行正确性检验的测试工作。程序单元是应用的最小可测试部件。...在过程化编程中,一个单元就是单个程序、函数、过程等;对于面向对象编程,最小单元就是方法,包括基类(超类)、抽象类、或者派生类(子类)中的方法。 集成测试,也叫组装测试或联合测试。...; 沙箱和快速:Jest虚拟化了JavaScript的环境,能模拟浏览器,并且并行执行; 快照测试:Jest能够对React 树进行快照或别的序列化数值快速编写测试,提供快速更新的用户体验; 支持异步代码测试...,并且在开发测试期间使用,用于判断在某些逻辑条件下会执行某种预期的结果。...[`react-comp snapshot test2 1`] = ` 我是react组件 `; 如果被测试代码有正常更新,可以使用“jest --updateSnapshot

    2.7K20

    你不知道的 Vue 单元测试(6000字实战单元测试)

    主流的单元测试运行器有很多,比如 Jest、Mocha 和 Karma 等,这几个在 Vue-Test-Utils 文档里都有对应的教程,这里我们只介绍 Vue-Test-Utils + Jest 结合的示例...Vue-Test-Utils 和 Jest 的 API 来写测试用例了。...test:unit ,执行它: cd first-vue-jest npm run test:unit 然后终端里会看到输出结果,PASS 表示测试用例通过了,这个是官方提供单元测试例子。...expect 是 Jest 内置的断言风格,业界还存在别的断言风格比如 Should、Assert 等。 toBe 是 Jest 提供的断言方法, 更多的可以到Jest Expect 查看具体用法。...● JavaScript 测试系列实战(一):使用 Jest 和 Enzyme 测试 React 组件● 你不知道的 Npm(Node.js 进阶必备好文)● 用动画和实战打开 React Hooks(

    11.5K41

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

    首先通过 jest.spyOn,我们便可以监听一个函数的使用情况,然后使用配套的 toBeCalled Matcher 来判断该函数是否被调用。整体代码十分简洁,同时也保持了很好的可读性。...我们测试的第一件事是检查修改输入值是否更改了我们的状态: 我们修改 app/components/TodoList.test.js 如下: import React from 'react'; import...为了进一步说明问题,让我们测试一下用户单击按钮后是否从我们的组件发送了实际的 post 请求。...从测试返回 promise 是确保 Jest 等待其异步方法执行结束的一种方法。 小结 在本文中,我们介绍了 mock 模块,并将其用于伪造API调用。...这就是我们使用 react-hooks-testing-library[4] 的原因,我们将在下一篇教程里讲解如何更加舒适的测试 React Hooks 的方法,敬请期待!

    4.8K20

    如何测试驱动开发 React 组件?

    什么是 TDD TDD(Test-driven development),就是测试驱动开发,是敏捷开发中的一项核心实践和技术,也是一种软件设计方法论。...测试组件 首先使用 create-react-app 初始化一个 react 项目。目前 cra 已经内置了 @testing-library/react 作为测试框架。...npx create-react-app my-react-app 我们先从测试文件开始。先创建了组件的目录“Confirmation” 并在其中添加一个“index.test.js”文件。...但是实际上,我将要测试的组件还不存在。 首先通过 getByRole 方法 查找 role属性等于dialog能否文档中找到。...现在我们得到了我们想要的组件渲染的 HTML ,现在我想要确保我可以从外部传递这个组件的按钮的回调函数,并确保它们在单击按钮时被调用。

    2.2K10

    如何测试驱动开发 React 组件?

    什么是TDD TDD(Test-driven development),就是测试驱动开发,是敏捷开发中的一项核心实践和技术,也是一种软件设计方法论。...测试组件 首先使用 create-react-app 初始化一个 react 项目。目前 cra 已经内置了 @testing-library/react 作为测试框架。...npx create-react-app my-react-app 我们先从测试文件开始。先创建了组件的目录“Confirmation” 并在其中添加一个“index.test.js”文件。...但是实际上,我将测试的组件还不存在。 首先通过 getByRole 方法 查找 role属性等于dialog能否文档中找到。...现在我们得到了我们想要的组件渲染的 HTML ,现在我想要确保我可以从外部传递这个组件的按钮的回调函数,并确保它们在单击按钮时被调用。

    2.1K10

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

    JavaScript测试教程–part 4:模拟 API 调用和模拟 React 组件交互 今天,我们进一步测试 React 组件。它涉及模拟组件交互和模拟 API 调用。你将学到两种方法,开始吧!...app/components/ToDoList.test.js import React from 'react'; import { shallow } from 'enzyme'; import ToDoList...app/components/ToDoList.test.js import React from 'react'; import { shallow } from 'enzyme'; import ToDoList...为了更进一步,让我们测试一下用户单击按钮后是否从的组件发送了实际的请求。...从测试中返回 promise 是能够确保 Jest 等待其解决的一种方法。 总结 在本文中,我们介绍了模拟模块,并将其用于伪造 API 调用。由于没有发出实际的请求要求,我们的测试可以更可靠、更快。

    3.7K10

    40道ReactJS 面试问题及答案

    防止默认行为: 在 HTML 中,为了防止事件的默认行为(例如,防止表单提交),您可以使用 event.preventDefault() 等方法。...在 React 中,您还在事件处理函数中使用 event.preventDefault(),但您在传递给该函数的事件对象上调用它。...以下是测试 React 应用程序的一些常用方法: 单元测试:使用 Jest 等测试框架以及 Enzyme 或 React 测试库等工具为各个组件编写单元测试。...您可以使用 Jest 和 React 测试库等工具来模拟用户交互并测试应用程序的整体行为。...最后,我们断言使用正确的表单数据调用了handleSubmit 函数。 快照测试:快照测试是一种捕获组件输出“快照”并将其与先前存储的快照进行比较的方法。 使用 Jest 创建和维护组件输出的快照。

    51510

    React Hook测试指南

    而在软件工程里面有很多不同类型的测试,例如单元测试(unit test),功能测试(functional test),性能测试(performance test)和集成测试(integration test...对于单元测试,被测试的对象是我们源代码的独立单元(individual unit),在面向过程编程语言(procedural programming)里面,单元就是我们封装的方法(function),在面向对象的编程语言...Jest的使用,所以我在这里将不为大家做具体的介绍,这里主要介绍一下我们常用到的Jest API: 常用API it/test it/test函数是用来定义测试用例(test case)的,它的函数签名是...mock 在Jest框架中用来进行mock的方法有很多,主要用到的是jest.fn()和jest.spyOn()。...yarn add -D react-test-renderer@^16.9.0 例子 现在就让我们看一个简单的同时使用Jest和react-hooks-testing-library来测试hook的例子

    1.7K10

    JavaScript 测试系列实战(一):使用 Jest 和 Enzyme 测试 React 组件

    本篇教程是 JavaScript 测试系列实战 的第一篇教程,首先介绍了测试的类型,然后主要通过一个 React 项目教会你如何使用 Jest 编写第一个测试,然后使用 Enzyme 对 React 组件进行浅层渲染...E2E 测试的重点是在我们正在运行的应用程序中模拟实际用户(例如模拟滚动、单击和键入等行为),并检查我们的应用程序是否从实际用户的角度运行良好。...所幸的是,Airbnb 作为重度使用 React 的先驱,早就提出了专门的解决方案:Enzyme。...Jest 测试文件中使用它。...配置 jest-enzyme 你应该还记得,在刚才的测试代码中,我们还是使用了 Jest 自带的 Matcher(toEqual)。

    3K10

    前端自动化测试探索和实践

    单元测试(Unit Test)有 Mocha, Ava, Karma, Jest, Jasmine 等。...Augular 的默认测试框架就是 Karma + Jasmine,而 React 的默认测试框架是 Jest。 Jest 被各种 React 应用推荐和使用。...Create React App 新建的项目就会默认配置 Jest,我们基本不用做太多改造,就可以直接使用。 采用何种测试思想?...(甚至是不懂编程的)使用自然语言来描述系统功能和业务逻辑,从而根据这些描述步骤进行系统自动化的测试 Jest 基本语法 「由于大厂普遍使用 React/Vue 进行开发,而 React/Vue 官方推荐的单元测试工具都是...下一篇将会为大家带来自动化测试框架 Jest 与 React 的配合,让大家真正能够在 React 的项目中落地,为生产提效!

    4.4K11
    领券