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

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

使用Enzyme简化测试代码 我们常常会提到,测试代码对于复杂代码的可维护性至关重要,但是测试代码本身的易于理解和编写,以及可读性和可维护性也同等重要。...而Enzyme则来自于活跃在JavaScript开源社区的Airbnb公司,是对官方测试工具react-addons-test-utils)的封装,它模拟了jQuery的API,非常直观并且易于使用和学习...完全的DOM渲染需要在全局范围内提供完整的DOM API,这也就意味着它必须在至少“看起来像”浏览器环境的环境中运行,如果不想在浏览器中运行测试,推荐使用mount的方法是依赖于一个名为jsdom的,...事实上,我们可以通过欺骗React Native让它返回常规的React组件而不是Native组件,然后就又能愉快地使用传统的JavaScript测试来单独测试React Native组件逻辑。...react-native-mock这个辅助,这是一个使用纯JavaScript将全部的React Native组件进行mock的第三方,只需要导入这个就可以对React Native组件进行渲染和测试

2.3K40

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

确保代码没有bug的一种方法就是编写测试用例。测试React hooks与测试一般程序的方式没有太大区别。 在本教程中,我们将了解如何通过使用带有hooks的to-do应用程序来实现这一点。...我们将介绍使用Enzyme和React Testing Library编写测试,这两个都能做到这一点。...如果你第一次使用Enzyme,我们之前发布过关于它的文章,《Enzyme如何在React应用中与Jest一起使用》。我们可以用他们来深入测试React Hooks。...使用react-testing-library测试 我们将为此写三个测试: 1、初始待办事项的渲染 2、我们可以加一个新的待办事项 3、我们可以删除一个待办事项 首先,我们安装需要的安装包: npm install...无论你是使用Enzyme或是enzyme与React Testing Library其中之一来写测试完全取决于你。不管怎样,试着使用linting,毫无疑问,你会很高兴你这样做了。

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

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

本篇教程是 JavaScript 测试系列实战 的第一篇教程,首先介绍了测试的类型,然后主要通过一个 React 项目教会你如何使用 Jest 编写第一个测试,然后使用 Enzyme 对 React 组件进行浅层渲染...因此这里建议直接使用 npx jest 执行测试。 编写第一组测试 每个测试文件通常有多个测试用例。Jest 允许我们通过 describe 函数对测试用例进行分组,它创建了一个可以组合多个测试的块。...所幸的是,Airbnb 作为重度使用 React 的先驱,早就提出了专门的解决方案:Enzyme。...Jest 测试文件中使用它。...但实际上,社区还提供了更好的选择——专门为 Enzyme 定制的 Matcher :enzyme-matchers。这些 Matcher 使得编写断言语句更轻松、更具可读性。

2.9K10

如何测试 React 路由 ?

前言 本文承接上文 如何测试 React 异步组件?,这次我将继续使用 @testing-library/react测试我们的 React 应用,并简要简要说明如何测试路由系统。...基本示例 以下代码使用 react-router V6 版本, V5 使用 Switch 包裹组件 通常我们的程序会写下如下代码: 首先我们有 2 个页面 src/routes/home.jsx 主页...from 'react' function AboutContent() { throw new Error('抛出一个测试错误') } export default function About...: 将程序和使用什么路由分开; 使用 MemoryRouter 来测试; 通过 userEvent.click 点击确保页面可以正确渲染; 提供一个公共包裹组件,通过遍历来测试每个页面,确保渲染 以上就是本文的全部内容...,那么如何测试 react hooks ?

2.1K20

React 组件测试技巧

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

4.9K00

React 测试驱动教程

Hello World Image 设置 Mocha,Chai,Sinon 和 Enzyme Mocha:将用于运行我们的测试。 Chai:是我们期待的。...应用非常广泛,允许使用 RSpec 一样的语法。 Sinon:将服务于 mocks/stubs/spies. Enzyme:将用于测试我们的 React components。...AirBnB 写的一个很漂亮的测试。 安装这些包: npm i mocha chai sinon --save-dev 如果我们希望能够使用 ES6 编写测试,那么我们需要在运行前对代码进行转译。...使用 Karma 的价值在于快速测试重载,可以多浏览器测试和最重要的是 webpack 预处理。...虽然我只使用 React 开发了数月,但我已经爱上它了。我希望本教程可以帮助你更深入地理解一些 React 测试的最佳实践。有任何问题或评论随时联系我。测试是我们的好朋友! 原文链接

4.6K20

如何测试 React 路由 ?

前言 本文承接上文 如何测试 React 异步组件?,这次我将继续使用 @testing-library/react测试我们的 React 应用,并简要简要说明如何测试路由系统。...基本示例 以下代码使用 react-router V6版本, V5 使用 Switch 包裹组件 通常我们的程序会写下如下代码: 首先我们有 2 个页面 src/routes/home.jsx 主页...from "react"; function AboutContent() { throw new Error("抛出一个测试错误"); } export default function About...: 将程序和使用什么路由分开; 使用 MemoryRouter 来测试; 通过 userEvent.click 点击确保页面可以正确渲染; 提供一个公共包裹组件,通过遍历来测试每个页面,确保渲染 以上就是本文的全部内容...,那么如何测试 react hooks ?

2.1K20

Robot Framework(5)- 使用测试

https://www.cnblogs.com/poloyy/category/1770899.html 前言 在RF 测试库里面,分为三种测试 标准测试 扩展测试 远程测试 标准测试 啥是标准...啥是扩展测试 标准以外的其他测试都统称为扩展测试,它们是在 RF 开源社区实现的各种;当然包括了你自己开发的测试 常见的扩展测试 常见领域 扩展 Web 自动化测试 SeleniumLibrary...Setting 名称既是大小写敏感的,也是空格敏感的 如果一个测试是在某个包里的,则必须指明完整的包名称路径【如: 】 MyLibrary.library2 测试的参数也可以使用默认值,不定数量参数...【如: 】 MyLibrary.library1 arg1 agr2 测试名称和参数都可以使用变量【如: ,其实导入的是 DateTime 】 Library ${LIBRARY} 可以导入测试的文件包括...对于资源文件,这些关键字在引用这些资源文件的地方也是可见的 Import Library 导入测试 导入测试的另一种方式是使用 提供的关键字 Import Library BuiltIn

72610

使用Echidna测试智能合约

为自己的智能合约指定并检查有用的属性。 我们将演示如何使用 crytic.io[6]来完成这些工作,它提供了 GitHub 集成和额外的安全检查。...在较高级别上,该提供了用于管理地址数组的便捷。一个典型的例子涉及使用地址白名单的访问控制。...我们想使用基于属性的测试来指定所有可能输入的一般行为,然后生成大量输入。编写行为的一般描述比编写任何单独的具体“给定输入 X,函数应该执行/返回 Y”测试更难。...Echidna 测试工具:hasDuplicate 测试的代码最明显的一点是它比本身大!在这种情况下,这种情况并不少见。...使用 Crytic 启动并运行 您可以通过下载和安装该工具或使用我们的 docker build 自行运行 Echidna 测试——但使用 Crytic 平台集成了基于 Echidna 属性的测试、Slither

65520

React 测试入门教程

越来越多的人,使用React开发Web应用。它的测试就成了一个大问题。 React的组件结构和JSX语法,不适用传统的测试工具,必须有新的测试方法和工具。...二、测试工具 React测试必须使用官方的测试工具,但是它用起来不够方便,所以有人做了封装,推出了一些第三方,其中Airbnb公司的Enzyme最容易上手。...官方测试工具的写法 Enzyme的写法 三、官方测试工具 我们知道,一个React组件有两种存在形式:虚拟DOM对象(即React.Component的实例)和真实DOM节点。...首先,在测试脚本之中,引入官方测试工具。...四、Enzyme Enzyme是官方测试工具的封装,它模拟了jQuery的API,非常直观,易于使用和学习。 它提供三种测试方法。

93540

React测试框架之enzyme

Enzyme的API和jQuery操作DOM一样灵活易用,因为它使用的是cheerio来解析虚拟DOM,而cheerio的目标则是做服务器端的jQuery。...Enzyme兼容大多数断言测试框架,如chai、mocha、jasmine等。...npm install --save react react-dom babel-preset-react 要完成渲染测试,除了enzyme之外,还需要Enzyme Adapter的支持,由于React...不需要DOM环境, 并可以使用jQuery的方式访问组件的信息; render:静态渲染,它将React组件渲染成静态的HTML字符串,然后使用Cheerio这个解析这段字符串,并返回一个Cheerio...组件渲染成静态的HTML字符串,然后使用Cheerio这个解析这段字符串,并返回一个Cheerio的实例对象,可以用来分析组件的html结构。

1.1K10

React 现代化测试

(代表: eslint、flow、TypeScript) 单元测试: 在奖杯模型中, 单元测试的职责是对一些边界情况或者特定的算法进行测试。...(代表: jest、mocha) 集成测试: 模拟用户的行为进行测试, 对网络请求、获取数据的数据等依赖第三方环境的行为进行 mock。...(代表: jest、react-testing-library) e2e 测试: 模拟用户在真实环境上操作行为(包括网络请求、获取数据数据等)的测试。...因为这段代码对于使用方来说是不存在问题的, 但是测试用例却抛出错误, 此时开发者不得不做'无用功'来调整测试用例适配新代码。...相较于 enzyme, react-testing-library 所提供的 api 更加贴近用户的使用行为, 使用其对上述测试用例进行重构: import { render, fireEvent }

92330

测试使用内存数据

在初始化数据和导入数据一文中,我们探索了在Spring Boot项目中如何创建数据的表结构,以及如何往数据中填充初始数据。...在程序开发过程中常常会在环境配置上浪费很多时间,例如在一个存在数据组件的应用程序中,测试用例运行之前必须保证数据中的表结构正确,并且已经填入初始数据。...对于良好的测试用例,还需要保证数据在执行用例前后状态不改变。 在之前应用的基础上,schema.sql文件中包含创建数据表结构的SQL语句、data.sql文件中包含填充初始数据的SQL语句。...BookPubApplicationTest @Test public void contextLoads() { assertEquals(3, bookRepository.count()); } 至此我们还都是使用外部数据...——MySQL,现在尝试使用内存数据H2,因此在src/test/resources目录下添加application.properties文件,内容是: spring.datasource.url=\

1.5K20

React Native自动化测试

我们期待你能帮助我们提高测试覆盖率,以及提供更多的测试代码或是测试用例。 使用Jest来测试 Jest是在命令行通过node来执行的纯js测试工具。测试代码放置在__tests__目录下。...你可以在react-native源代码的根目录中使用如下命令来运行现有的jest测试代码: npm test 我们建议你在贡献代码的时候也添加自己的测试代码。...单元测试 (Android) React Native使用Buck编译工具来运行测试。 单元测试部分直接在本地运行,不需要模拟器。.../scripts/run-android-local-unit-tests.sh 集成测试 (Android) React Native使用Buck编译工具来运行测试。...这类测试首先渲染一个组件,然后使用TestModule.verifySnapshot()比对屏幕截图与参考效果图,其原理是利用了FBSnapshotTestCase这个

3K60

扫码

添加站长 进交流群

领取专属 10元无门槛券

手把手带您无忧上云

扫码加入开发者社群

相关资讯

热门标签

活动推荐

    运营活动

    活动名称
    广告关闭
    领券