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

如何使用Jest/Enzyme测试React中的keydown事件?

Jest和Enzyme是两个常用的JavaScript测试工具,用于测试React应用程序中的组件。在React中测试keydown事件的方法如下:

  1. 首先,安装Jest和Enzyme依赖包。可以使用npm或者yarn进行安装。
代码语言:txt
复制
npm install --save-dev jest enzyme enzyme-adapter-react-16
  1. 创建一个测试文件,命名为Component.test.js,并导入所需的依赖。
代码语言:txt
复制
import React from 'react';
import { shallow } from 'enzyme';
import Component from './Component';
  1. 在测试文件中,使用describe函数定义一个测试套件,并使用it函数定义一个具体的测试用例。
代码语言:txt
复制
describe('Component', () => {
  it('should handle keydown event', () => {
    const wrapper = shallow(<Component />);
    const event = { key: 'Enter' };
    wrapper.find('input').simulate('keydown', event);
    // 在这里编写断言,验证组件在接收到keydown事件后的行为
  });
});
  1. 运行测试。在命令行中执行以下命令:
代码语言:txt
复制
npm test

这将运行Jest并执行测试文件中的测试用例。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

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

在这一系列实战教程,我们将手把手带你掌握 JestEnzyme、Cypress 等测试利器,帮助我们从 bug 沼泽挣脱出来,成为一个无往不利高阶前端开发者!...本篇教程是 JavaScript 测试系列实战 第一篇教程,首先介绍了测试类型,然后主要通过一个 React 项目教会你如何使用 Jest 编写第一个测试,然后使用 EnzymeReact 组件进行浅层渲染...所幸是,Airbnb 作为重度使用 React 先驱,早就提出了专门解决方案:Enzyme。...Jest 测试文件中使用它。...配置 jest-enzyme 你应该还记得,在刚才测试代码,我们还是使用Jest 自带 Matcher(toEqual)。

3K10

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

在之前两篇教程,我们学会了如何测试最简单 React 组件。在实际开发,我们组件经常需要从外部 API 获取数据,并且组件交互逻辑也往往更复杂。...在这篇教程,我们将学习如何测试更复杂组件,包括用 Mock 去编写涉及外部 API 测试,以及通过 Enzyme 来轻松模拟组件交互 初次尝试 Jest Mock 我们应用程序通常需要从外部...由于没有发起实际 post 请求,我们测试可以更可靠,更快。除此之外,我们还在整个 React 组件模拟了事件。我们检查了它是否产生了预期结果,例如组件请求或状态变化。...不幸是,测试钩子并没有那么简单。在本文中,我们研究了如何使用 react-hooks-testing-library[2] 处理它。...这就是我们使用 react-hooks-testing-library[4] 原因,我们将在下一篇教程里讲解如何更加舒适测试 React Hooks 方法,敬请期待!

4.8K20
  • Jest:给你 React 项目加上单元测试

    Jest 是一款轻量 JavaScript 测试框架,它卖点是简单好用,由 facebook 出品。本文就简单讲讲如何使用 JestReact 组件进行测试。 为什么需要单元测试?...单元测试(Unit Testing),指的是对程序模块(最小单位)进行检查和验证。比如一个函数、一个类、一个组件,它们都是模块。 使用单元测试优点: 更好地交付高质量代码。...Jest 基本使用 我们先写一个简单函数,作为被测试模块。...但 Jest 本身并不支持 React 组件测试 API,需要使用另外一个内置 React Testing Library 库来测试 React 组件。...官方只支持到 React 16,Enzyme 已死: https://dev.to/wojtekmaj/enzyme-is-dead-now-what-ekl 使用 Jest 测试 React 组件

    2.9K20

    使用storybook管理React组件

    本文已ReactUI组件为例,演示如何新建/集成Storybook到项目中,并对UI组件进行全方位管理,包括发布、demo文档、测试等。 1....测试UI组件 4.1 写测试用例原因 找到bug 新修改没有改变已有的接口和功能 将测试用例作为文档 4.2 测试结构 使用storyshots插件来实现,其核心是使用Jest,原理是每次生成一份DOM...4.3 测试交互 storybook交互性测试可以使用 Enzyme来模拟用户输入,然后使用Mocha or Jest来进行结果测试,storybook又一个专门插件帮助我们集成他们:specifications.../config.js配置enzyme import { configure as enzymeConfigure } from 'enzyme'; import Adapter from 'enzyme-adapter-react...-16'; enzymeConfigure({ adapter: new Adapter() }); 在stories/test.js编写测试用例: import React from 'react

    3.4K20

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

    JavaScript测试教程-part 1:用 Jest 进行单元测试 2. JavaScript测试教程–part 2:引入 Enzyme测试 React 组件 3....它是前面提到过 ShallowWrapper 功能。我们用它来模拟事件。第一个参数是事件类型(由于在输入中使用了 onChange,因此在这里应该用 change),第二个参数是模拟事件对象。...从测试返回 promise 是能够确保 Jest 等待其解决一种方法。 总结 在本文中,我们介绍了模拟模块,并将其用于伪造 API 调用。由于没有发出实际请求要求,我们测试可以更可靠、更快。...除此之外,我们还在整个 React 组件模拟了事件,并检查了它是否产生了预期结果,例如组件请求或状态变化,并且了解了监视概念。 1....JavaScript测试教程-part 1:用 Jest 进行单元测试 2. JavaScript测试教程–part 2:引入 Enzyme测试 React 组件 3.

    3.7K10

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

    下面让我们看一个简单计数器例子,以及两个相应测试:第一个是使用 Enzyme[4] 编写,第二个是使用 React Testing Library[5] 编写。...触发事件通常会触发应用程序一些更改,因此我们必须执行一些断言来确保这些更改发生。在我们测试,这样做一个好方法是确保呈现给用户计数已经更改。...注意:这个AAA模式并不特定于测试库。事实上,它甚至是任何测试用例一般结构。我在这里向您展示这个是因为我发现测试如何方便地在每个部分编写测试是一件很有趣事情。...fireEvent 有几个可以用来测试事件方法,因此您可以自由地深入文档了解更多信息。 现在我们已经知道了如何测试事件,接下来我们将在下一节中学习如何处理异步操作。 4....对于第一个测试,我们检查内容是否等于About页面文本,对于第二个测试,我们测试路由参数并检查它是否正确通过。 现在我们可以进入最后一节,学习如何测试Axios请求。 8.

    14.9K33

    React 造轮子系列:Icon 组件思路

    React.FunctionComponent 与 IconPropps 本轮子使用 React + TypeScript 来写,那么在 ts 如何声明函数组件及级 Icon 组件传递参数呢,答案是使用...首先我们对我们 classes 方法时行单元测试,这里使用 Jest 时行测试,也是 React 官网推荐。...Snapshot测试UI 这里测试 UI 相关还需要使用一个库 Enzyme , Enzyme 来自 airbnb 公司,是一个用于 React JavaScript 测试工具,方便你判断、操纵和历遍...Enzyme API 通过模仿 jQuery API ,使得 DOM 操作和历遍很灵活、直观。Enzyme 兼容所有的主要测试运行器和判断库。...image.png 解决办法: yarn add -D @types/jest 在文件开头加一句 import 'jest' 这是因为 describe 和 it 定于位于 jest 类型声明文件

    2.1K20

    React 造轮子系列:Icon 组件思路

    React.FunctionComponent 与 IconPropps 本轮子使用 React + TypeScript 来写,那么在 ts 如何声明函数组件及级 Icon 组件传递参数呢,答案是使用...首先我们对我们 classes 方法时行单元测试,这里使用 Jest 时行测试,也是 React 官网推荐。...Snapshot测试UI 这里测试 UI 相关还需要使用一个库 Enzyme , Enzyme 来自 airbnb 公司,是一个用于 React JavaScript 测试工具,方便你判断、操纵和历遍...Enzyme API 通过模仿 jQuery API ,使得 DOM 操作和历遍很灵活、直观。Enzyme 兼容所有的主要测试运行器和判断库。...image.png 解决办法: yarn add -D @types/jest 在文件开头加一句 import 'jest' 这是因为 describe 和 it 定于位于 jest 类型声明文件

    4.7K70

    Unit Testing

    #配置单元测试 #安装 Jest 我们使用 yarn 来安装 Jest 包 yarn add -D jest 在 package.json 文件中加入测试命令 { "scripts": {..."test": "jest" } } 之后只需要在 Command Line 输入 yarn test 即可开启测试 #配置时遇到麻烦 在我配置 Jest 时遇到了几个麻烦,让我测试代码运行不起来...from 'enzyme-adapter-react-16' Enzyme.configure({ adapter: new Adapter() }) 其他配置可以参考官网配置文档来进行进一步配置...但是如果你将所有的代码都写了单元测试,那么我觉得你是把全身安全带都绑上了,只露了一只眼睛,你开发工作将举步难行,下面来说说单元测试应该覆盖哪些,不应该覆盖哪些 组件类型/测试内容 分支渲染逻辑 事件调用...在表格,建议是在 100% 覆盖率 #参考 Jest React 测试技巧 React 单元测试策略及落地 单元测试-维基百科

    1.3K20

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

    我希望通过对这些工具各自作用掌握,了解完整前端测试技术方案。前端单元测试领域也很多,这里主要讲对于前端组件如何进行单元测试,最后会主要介绍下对于 React 组件一些测试方法总结。...,而且支持功能更加清晰,不用考虑如何组合使用问题,而且下文介绍 jest 测试框架也是使用这种风格。...jest Jest 是 facebook 出一个完整单元测试技术方案,集 测试框架, 断言库, 启动器, 快照,沙箱,mock工具于一身,也是 React 官方使用测试工具。...使用 Jest + EnzymeReact 进行单元测试 ?...另外测试 React组件除了 Enzyme 提供操作, Jest 还有很多其他有用特性,比如可以 mock 一个 npm 组件实现,调整 setTimeout 时钟等,真正进行单元测试时,这些工具也是必不可少

    9.6K20

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

    JavaScript测试教程–part 4:模拟 API 调用和模拟 React 组件交互 在本教程第一篇,我们简要介绍了单元测试基础。这次要更进一步,使用 Enzyme测试 React。...在第一个测试,我们使用了 toContainReact 函数,这是一个自定义匹配器函数。它是 enzyme-matchers 库一部分。...要将其与 Jest 一起使用,请安装 jest-enzyme 包。 1npm install jest-enzyme 最后要做是将其导入 setupTests 文件。...总结 本文中我们已经了解了使用 Enzyme 测试 React 组件基本知识。我们已经介绍了安装 Enzyme 并运行第一个简单测试使用渲染类型称为“浅渲染”。...在编写单元测试时,它工作得很好。在本教程后续部分,我将介绍其他类型渲染,并学习如何测试程序不同部分。它将包括快照测试和模拟数据之类技术。下次见!

    1.4K50

    JavaScript 测试系列实战(二):深层渲染和快照测试

    在上一篇教程,我们已经介绍了使用 Enzyme 测试 React 组件基本知识。...今天,我们将更深入地挖掘并学习如何测试组件 Props,如何(以及为什么)使用 mount 函数,以及什么是 Jest 快照测试。...通常我们会在集成测试使用 mount 函数,测试组件之间如何协同工作,而不仅仅是作为独立单元。 如果你不了解单元测试和集成测试这两个术语,可以看下本系列第一篇教程。...在测试与 DOM 交互或者在处理高阶组件时,mount 函数也可以派上用场。_Mount 使用 DOM 实现模拟,Jest 默认使用是 jsdom。...- END - ● JavaScript 测试系列实战(一):使用 JestEnzyme 测试 React 组件● 你不知道 Npm(Node.js 进阶必备好文)● 用动画和实战打开 React

    2.1K20

    【译】使用EnzymeReact Testing Library测试React Hooks

    确保代码没有bug一种方法就是编写测试用例。测试React hooks与测试一般程序方式没有太大区别。 在本教程,我们将了解如何通过使用带有hooksto-do应用程序来实现这一点。...我们将介绍使用EnzymeReact Testing Library编写测试,这两个库都能做到这一点。...如果你第一次使用Enzyme,我们之前发布过关于它文章,《Enzyme如何React应用Jest一起使用》。我们可以用他们来深入测试React Hooks。...我们使用断言,在进一步模拟单击事件之前,输入“修复失败测试”,该事件应该将新项目添加到待办事项列表。 最后,断言列表中有三个项,并且第三个项与我们创建项相等。...因为我们只想删除一个项目,所以我们对集合第一个项目触发一个click事件,它应该删除第一个待办事项。这应该使待办事项子节点长度等于1。 这些测试也可以在GitHub上找到。

    4.1K30

    年轻时,我不写单元测试

    其实之前就已经简单了解过了单元测试,但当时对于单元测试我是持有一种很否定态度,因为他太过于鸡肋,都是测试一些很基础功能,但是当笔者被这次重构折磨之后,有重新思考了下如何能够保证代码健壮性,抱着这个态度...,关于不同测试框架重点,这篇文章就不详细展开了,最终结合我们项目,最终采用了facebookjest+enzyme。...重点将展开以下两种react组件类型测试。 展示型组件测试 展示型组件测试,意思就是要确保每一次修改都是符合预期,这里笔者要着重介绍下jest框架里面的snapshot功能。...但是仔细想想,这其实就违背了我们单元测试初衷,笔者这里也大胆猜测下,jest官方在实现这个功能时候,应该也只是想记录下一步一步事件后,当前组件html结构,对比上一次快照,来看功能是否符合预期...一开始我觉得单元测试很鸡肋原因也是没有深入了解它,这次发现就算是和业务结合很紧密组件,也能够模拟正常操作,这里就贴一个和redux结合组件来举例 import React from 'react

    86920

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

    前言 如果你熟悉React和Echarts的话,应该有用到过 echarts-for-react(虽然它现在没有维护了),本文就通过它写测试用例来学习下如何写单元测试 如何测试function 有如下函数...,作用是「浅复制objkeys」,如何判断它返回是期待结果?...② 当测试函数比较复杂时,非常方便,不用了解内部详细代码,只需返回值符合期望即可 如何测试ReactComponent 当我写完一个React组件时,我该如何测试它呢?...通过本文,你应该知道 ① jest.useFakeTimers()作用及何时使用如何测试function ③ 如何测试ReactComponent ④ mount()/shallow()/render...()区别 ⑤ toEqual()和toBe()区别 ⑥ 如何测试DOM节点上属性 ⑦ 如何测试React组件实例上属性 ⑧ 如何测试组件上props ⑨ jest.fn()作用 ⑩ 如何测试组件已卸载

    6.2K50

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

    一、技术选型: Jest + Enzyme + react-hooks-testing-library 1.1 jest Jest是FaceBook出品前端测试框架,适合用于ReactReact...1.2 Enzyme Enzyme是AirBnb开源React测试工具库,通过一套简洁api,可以渲染一个或多个组件,查找元素,模拟元素交互(如点击,触摸),通过和Jest相互配合可以提供完整...Hooks测试支持,仅支持React 16.9.0以上 "babel-jest": "^24.8.0", "enzyme": "^3.10.0", "enzyme-adapter-react...快照将在测试文件的当前文件路径自动生成snapshots文件夹中保存。当主动修改造成ui变化时,使用jest -u来更新快照。..._onClear).toBeCalled();//测试组件实例上方法是否被调用 九、Redux测试使用React或者React Native时通常会使用Redux进行状态管理,需要mock store

    6.1K30

    前端自动化测试

    : 保证当前组件质量,即当前业务正常使用 在新需求下,旧组件如果能满足新需求50%以上功能,应当升级旧组件满足新需求,同时兼容旧业务 除该组件Owner之外第二人,在修改组件过程,避免因为对代码不熟悉...,改出BUG 一个组件多个页面复用,修改后测试回归任务重 技术选型 目前前端整体测试框架较为常用有: Jest Mocha Jest 源自Facebook,Jest 一个理念是提供一套完整集成...React项目测试选型 react-addons-test-utils:官方API,有些晦涩 Enzyme:源自Airbnb,封装了React官方测试API,类Jquery风格简洁API, 使得Dom...操作变得十分友好 综合目前市面上轮子,我们技术选型为Jest+Enzyme 实践 例子是一个基于Antd二次封装单选年日期选择器,如下演示: 图片 代码结构如下 图片 其中测试相关文件,...这里可以首先简单看一下,Jest+Enzyme基本语法: JestAPI更多着力于定义测试、断言、mock库 定义测试: describe: 定义一个测试套件(test suite) it: 定义一个测试

    2K20

    React总结(三)】React 组件自动化测试与持续集成指北(1)

    enzyme: EnzymeReact JavaScript 测试实用程序,可以更轻松地测试 React Components 输出。...常量: 一旦常量被定义,他们不应该是经常改变,可以把他们理解为一个静态代码集,无需加入到组件测试用例。 内联样式: 为了测试内联样式,需要使用测试样式复制对象。...下面来聊一下如何测试用例,我总结分为两个方法: Snapshot 快照测试 组件业务逻辑测试 建议阅读下面内容之前,先了解一下 Enzyme 基本 api: https://github.com/airbnb...⚙️如何测试组件逻辑 1、创建一个 snapshot 一个需要被测试组件往往只需要创建一个 snapchat,具体使用方法可以像上面的说明一样操作,没必要创建多个 snapshot。...3、模拟事件触发来测试组件 通过 snapshot 测试和 props 测试,已经能确保组件是可以正常渲染了,但是这还远远不够,因为有很多分支代码我们是没有覆盖到,如果你查看 jest --coverage

    2.4K80

    Jest + React Testing Library 单测总结

    2、Jest 使用 Jest 安装这里就不赘述了,如果使用 create-react-app 来创建项目,JestReact Testing Library(RTL) 都已经默认安装了。...如果想要看如何安装 Jest,可以参考:Jest 上手。 Jest 常用配置项在根目录 jest.config.js ,常用配置可以参考:Jest 配置文件。...运行指定文件测试用例),就可以得到测试结果,如: 当然,如果想要看到覆盖率报告,可以使用 jest --coverage,或者 jest-report。...扩展阅读材料 Jest 学习指南 那些年错过 React 组件单元测试 使用 Jest 测试 JavaScript (Mock 篇) 3、React Testing Library testing...3.1 render & debug 在测试用例渲染内容,可以使用 RTL 库 render,render 函数可以为我们在测试用例渲染 React 组件。

    4.6K20
    领券