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

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

测试的类型 单元测试 单元测试的目标可以是一个函数,一个类,或者一个模块。单元测试应该是相互隔离和独立的。对于给定的输入,单元测试检查结果。...E2E 测试的重点是在我们正在运行的应用程序中模拟实际用户(例如模拟滚动、单击和键入等行为),并检查我们的应用程序是否从实际用户的角度运行良好。...初识 Enzyme:编写第一个 React 组件测试 很显然,我们不会仅仅满足于测试像 divide 那样简单的函数,我们希望能够测试一个 React 组件,但是和一个普通的 JavaScript...安装和配置 Enzyme 首先安装 Enzyme 和相应的 React 适配器: npm install enzyme enzyme-adapter-react-16 我们需要配置一下 Enzyme,才能在...小结 在过去的两个小节中,我们了解、安装和配置了 Enzyme,并且接触了 shallow 浅层渲染这个单元测试利器,并且循序渐进测试了两个 React 组件。

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

    memmove函数和memcpy函数的模拟实现

    首先我们来了解memmove函数和memcpy函数的使用 memmove函数 他的函数所需参数如下 1.函数memcpy从source的位置开始向后复制num个字节的数据destination 指向的内存位置...下面我们就可以对memmove函数进行模拟实现 我们定义此模拟实现函数为my_memmove 我们定义数组 arr[]={1,2,3,4,5,6,7} 我们想要将数组中数字3,4,5放入1,2,3的位置中...相对于memmove函数,memcpy的功能就没有怎么完整了,memmove和memcpy的差别就是memmove函数处理的源内存块和⽬标内存块是可以重叠的,所以,如果源空间和⽬标空间出现重叠,就得使...memcpy的模拟实现和memmove的差别不大 代码如下 void * memcpy ( void * det, const void * src, size_t size) { void * ret...memmove函数模拟实现的一部分,就是只采用了从前向后的方式进行内存更改,所以这里我就不做过多的解释了,大家自行理解。

    21710

    React 设计模式 0x8:测试

    # 使用 Jest 进行集成测试 在大多数 React 应用程序中,通常需要与外部 API 集成以在应用程序中发布和获取数据。 可以使用 Jest 来测试 API 行为,以查看预期和意外结果。...模拟函数 使用 模拟函数 来侦测(查看)我们的函数被调用的情况,或者使用它来测试单个函数或整个模块。...在 Jest 中有以下三种类型的模拟函数: Jest.fn(用于模拟单个函数) Jest.mock(用于模拟整个模块) Jest.spyOn(用于查看函数的调用情况) 更多信息请访问 https://jestjs.io...React 组件的工具和函数 编写测试用例 编写完整的测试用例,覆盖组件的所有代码路径,包括正常情况和异常情况 使用快照测试 使用 Jest 中的快照测试功能来验证组件是否按预期呈现 使用模拟数据...使用模拟数据来测试组件,以确保它们在不同的数据情况下都能正常工作 使用模拟函数 使用模拟函数来模拟组件的依赖项和外部接口,以便更好地控制测试环境 集成测试 编写集成测试来测试应用程序的整个流程

    2.4K10

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

    在较大规模的前端项目中,测试对于保证代码质量十分重要,而React的组件化和函数式编程, 这种相同输入一定返回相同输出的幂等特性特别适合单元测试。...本篇即是React和React Native项目单元测试的完整方案介绍。...一、技术选型: Jest + Enzyme + react-hooks-testing-library 1.1 jest Jest是FaceBook出品的前端测试框架,适合用于React和React...1.2 Enzyme Enzyme是AirBnb开源的React测试工具库,通过一套简洁的api,可以渲染一个或多个组件,查找元素,模拟元素交互(如点击,触摸),通过和Jest相互配合可以提供完整的...@ctrip|react-native)'], //transform白名单 }; 三、Jest简单函数单元测试 待测试函数 function add(x, y) { return x + y;

    7K30

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

    JavaScript测试教程–part 3:测试 props,挂载函数和快照测试 4....JavaScript测试教程–part 4:模拟 API 调用和模拟 React 组件交互 今天,我们进一步测试 React 组件。它涉及模拟组件交互和模拟 API 调用。你将学到两种方法,开始吧!...Node 的某些核心模块(例如 fs 或 path ),则需要在模拟文件中明确调用 jest.mock('moduleName') Jest 允许我们对函数进行监视:接下来测试是否调用了我们所创建的...('axios'),Jest 在的测试和组件中都用我们的模拟代替了 axios。...spyOn 函数返回一个 mock函数。有关其功能的完整列表,请阅读文档。我们的测试检查组件在渲染和运行之后是否从模拟中调用 get函数,并成功执行。

    4.5K10

    Web前端实现锚点功能的三种方式

    默认为 "start",元素顶部将滚动到视窗顶部; 取值 "end",元素底部将和视窗底部对齐; 取值 "center",元素中线将和视窗中间对齐; 取值 "nearest",元素将就近对齐。...三、scrollTo/scrollBy window.scrollTo 可将视窗滚动到指定的坐标。...用法如: window.scrollTo(xpos, ypos); window.scrollBy 可将视窗向上下或左右移动指定坐标的距离。...用法如: window.scrollBy(xnum, ynum); 这种方式还需要实用 Element.getBoundingClientRect 来获取元素的大小及相对于当前视窗的位置。...Element.getBoundingClientRect 的返回值包含 top、left、bottom、right、width 和 height 六个属性,除了 width 和 height 以外的属性均是相对于视窗的左上角来计算的

    4.1K31

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

    在这篇教程中,我们将学习如何测试更复杂的组件,包括用 Mock 去编写涉及外部 API 的测试,以及通过 Enzyme 来轻松模拟组件交互 初次尝试 Jest Mock 我们的应用程序通常需要从外部的...首先通过 jest.spyOn,我们便可以监听一个函数的使用情况,然后使用配套的 toBeCalled Matcher 来判断该函数是否被调用。整体代码十分简洁,同时也保持了很好的可读性。...我们用它来模拟事件。它第一个参数是事件的类型(由于我们在输入中使用onChange,因此我们应该在此处使用change),第二个参数是模拟事件对象(event)。...除此之外,我们还在整个 React 组件中模拟了事件。我们检查了它是否产生了预期的结果,例如组件的请求或状态变化。为此,我们了解了 spy 的概念。...让测试通过 React文档[3] 里面提到:我们只能从函数式组件或其他 Hooks 中调用 Hooks。

    5.6K20

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

    JavaScript测试教程–part 3:测试 props,挂载函数和快照测试 4....JavaScript测试教程–part 4:模拟 API 调用和模拟 React 组件交互 在本教程的第一篇中,我们简要介绍了单元测试的基础。这次要更进一步,使用 Enzyme 库测试 React。...我们在这里用了 Jest,不过 Enzyme 也可以与 Mocha 和 Chai 之类的库一起使用。 Enzyme 基础 Enzyme 是一个库,用于在测试时处理你的 React 组件。...这里要注意一个非常重要的点:即使我们用了 Enzyme,但测试运行程序仍然是 Jest。由于我们用的是 expect 函数,因此可以使用各种可供调用的匹配器函数。我已经在课程的第一部分中提到了它们。...它将包括快照测试和模拟数据之类的技术。下次见!

    1.6K50

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

    由于 mount 函数会模拟实际的 DOM,渲染成本更高,因此运行测试会花费更多的时间。通常我们会在集成测试中使用 mount 函数,测试组件之间如何协同工作,而不仅仅是作为独立的单元。...如果你不了解单元测试和集成测试这两个术语,可以看下本系列第一篇教程。 在测试与 DOM 的交互或者在处理高阶组件时,mount 函数也可以派上用场。..._Mount 使用 DOM 实现的模拟,Jest 默认使用的是 jsdom。我们可以通过调整 testEnvironment 属性更改。 快照测试 快照测试是 Jest 的一大招牌功能。...小结 在本文中,我们介绍了如何直接去测试组件的 Props,并学习了 mount 函数和浅层渲染之间的区别。...- END - ● JavaScript 测试系列实战(一):使用 Jest 和 Enzyme 测试 React 组件● 你不知道的 Npm(Node.js 进阶必备好文)● 用动画和实战打开 React

    2.5K20

    React Native单元测试

    概述 所谓单元测试,就是对每个单元进行的测试,一般针对的是函数、类或单个组件,不涉及系统和集成,单元测试是软件测试的基础测试,一个完备的软件系统都会涉及到单元测试。...目前,Javascript的测试工具很多,但是针对React的测试主要使用的是Facebook推出的Jest框架,Jest是基于Jasmine的JavaScript测试框架,具有上手容易、快速、可靠的特点...相比其他的测试框架,Jest具有如下的一些特点: 适应性:Jest是模块化、可扩展和可配置的; 沙箱和快速:Jest虚拟化了JavaScript的环境,能模拟浏览器,并且并行执行; 快照测试:Jest能够对...React 树进行快照或别的序列化数值快速编写测试,提供快速更新的用户体验; 支持异步代码测试:支持promises和async/await; 自动生成静态分析结果:不仅显示测试用例执行结果,也显示语句...、分支、函数等覆盖率。

    1.1K20

    除了Jest,还有哪些工具可用于Mock外部依赖?

    除了 Jest,还有多种工具可用于在测试中模拟(Mock)外部依赖,这些工具适用于不同的测试框架和场景。以下是一些常用的替代工具及其适用场景:1....核心功能: 模拟函数(sinon.stub()) 监视函数调用(sinon.spy()) 模拟定时器和 XHR 请求 示例:模拟 API 调用import sinon from 'sinon';...核心功能: td.function():创建模拟函数 td.when():定义函数调用的条件和返回值 td.verify():验证函数调用 示例:模拟工具函数import td from 'testdouble...react-hooks';import useFetch from '....简单场景:直接使用测试框架内置的 Mock 功能(如 Jest、Vitest 的 Mock)。 这些工具各有侧重,实际项目中可根据测试框架、场景复杂度和团队熟悉度选择合适的方案。

    13510

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

    Jest 关于Jest,我们参考一下其Jest 官网[1],它是Facebook开源的一个前端测试框架,主要用于React和React Native的单元测试,已被集成在create-react-app...Jest特点: 零配置 快照 隔离 优秀的 api 快速且安全 代码覆盖率 轻松模拟 优秀的报错信息 Enzyme Enzyme是Airbnb开源的React测试工具库,提供了一套简洁强大的API,并内置...如果React的版本是15或者16,需要安装对应的enzyme-adapter-react-15和enzyme-adapter-react-16并配置。...实际上,jest.spyOn()是jest.fn()的语法糖,它创建了一个和被spy的函数具有相同内部代码的mock函数。 Snapshot 快照测试 所谓snapshot,即快照也。...总结 到这里,关于前端单元测试的一些基础背景和Jest的基础api就介绍完了,在下一篇文章中,我会结合项目中的一个React组件来讲解如何做组件单元测试。 ?

    5.9K20

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

    前言 如果你熟悉React和Echarts的话,应该有用到过 echarts-for-react(虽然它现在没有维护了),本文就通过它写的测试用例来学习下如何写单元测试 如何测试function 有如下函数...,可以保证该函数的返回值仍保持不变,进而不会影响到使用到该函数的旧需求 ② 当测试的函数比较复杂时,非常方便,不用了解内部的详细代码,只需返回值符合期望即可 如何测试ReactComponent 当我写完一个...测试用例 import React from 'react'; //enzyme库用来判断、操纵和遍历 ReactComponents import {mount} from 'enzyme'; import...=> { // mount()借助jsdom模拟浏览器环境,并提供DOM api和生命周期的支持,方便测试HOC(高阶组件) // shallow()浅渲染,将组件渲染成虚拟DOM对象,...组件 ② mount()/shallow()/render()的区别如下: [1] mount()借助jsdom模拟浏览器环境,并提供DOM api和生命周期的支持,方便测试HOC(高阶组件) [2]

    6.6K50

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

    单元测试(Unit Testing),指的是对程序中的模块(最小单位)进行检查和验证。比如一个函数、一个类、一个组件,它们都是模块。 使用单元测试的优点: 更好地交付高质量代码。...Jest 基本使用 我们先写一个简单的函数,作为被测试的模块。...React Testing Library 本文不讲解安装和配置,我们先用 CreateReactApp 来搭建项目,并使用 TypeScript 模板。...但 Jest 本身并不支持 React 组件的测试 API,需要使用另外一个内置的 React Testing Library 库来测试 React 组件。...React Testing Library 是 以用户为角度 的测试库,能够模拟浏览器的 DOM,将 React 组件挂载上去后,我们使用其提供的一些模拟用户操作的 API 进行测试。

    3.5K20

    对 React 组件进行单元测试

    React 单元测试中用到的工具 Jest 不同于"传统的"(其实也没出现几年)的 jasmine / Mocha / Chai 等前端测试框架 -- Jest的使用更简单,并且提供了更高的集成度、更丰富的功能...它模拟了 jQuery 的 API,非常直观并且易于使用和学习,提供了一些与众不同的接口和几个方法来减少测试的样板代码,方便判断、操纵和遍历 React Components 的输出,并且减少了测试代码和实现代码之间的耦合...对于一些组件和共有函数等,完善的测试也是一种最好的使用说明书。...方法等获取 解决的办法是模拟一个渲染到容器组件原处的普通组件: //FakeReactBootstrapModal.jsimport React, {Component} from 'react';class...sinon 中有一些模拟 XMLHttpRequest 请求的方法, jest 也有一些第三方的库解决 fetch 的测试; 在我们的项目中,根据实际的用法,自己实现一个类来模拟请求的响应: //FakeFetch.jsimport

    5.2K40

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

    测试工具的价值,并非简单地生成通过率报告,而是构建一套与开发流程共生的验证体系——用Jest拆解逻辑单元的细枝末节,借React Testing Library模拟用户与界面的真实交互,让测试从“事后检查...Jest的高效运用,在于对组件逻辑的精准拆解与隔离。React组件的复杂性往往源于状态管理与业务逻辑的交织,而Jest提供的模拟机制,能像外科手术般剥离外部依赖,聚焦核心逻辑的验证。...例如,测试一个购物车组件时,Jest可验证商品数量变化的计算是否正确,React Testing Library则模拟添加商品、修改数量的操作,检查页面总价是否实时更新,这种分层验证既确保了逻辑正确性,...例如,测试一个调用了工具函数的组件时,应模拟工具函数的返回值而非内部实现,这样即使工具函数重构,只要返回值不变,测试就能保持有效。...Jest提供的异步处理机制与React Testing Library的waitFor函数,正是为解决这类问题设计,善用这些工具能大幅提升测试的稳定性。

    9700
    领券