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

「前端架构」Grab的前端学习指南

在React中进行测试很容易,因为组件的接口定义良好,可以通过向组件提供不同的道具和状态并比较呈现的输出来测试组件。 可维护性——以基于组件的方式编写视图可以促进可重用性。...这使得在大规模重构过程中很容易对组件进行移位,只要向组件提供相同的支持即可。 高性能——您可能听说过React使用虚拟DOM(不要与影子DOM混淆),当状态发生变化时,它会重新呈现所有内容。...React附带了一些测试工具,但是通过类似于jquery的API,通过Airbnb提供的可以更容易地生成、断言、操作和遍历React组件的输出。建议用测定反应组分。...Jest使编写前端测试变得有趣和容易。因为定义了明确的职责和接口,所以React组件和Redux操作/缩减器相对容易测试也很有帮助。...对于React组件,我们可以测试给定一些道具,呈现所需的DOM,并在某些模拟用户交互触发回调。对于Redux还原器,我们可以测试给定的一个先验状态和一个动作,会产生一个结果状态。

7.4K20

Unit Testing

#应该测试你的程序 其实每一个项目都应该使用单元测试,单元测试可以很好的保证你的代码不会欺骗你。 世界上没有任何一个完美的程序,也更不会有完美的人可以写出没有任何问题的代码。...运行 Jest 测试代码出现 Cannot use import statement outside a module 不能在其他模块使用 import 语句 出现这个问题的主要原因在于 Webpack...,我们其实并不会对项目中所有的代码进行测试。...纯 UI 展示型组件 ✅ ✅ ❌ 容器型组件 ✅ ✅ ❌ 通用 UI 组件 ✅ ✅ ❌ 功能型组件 ✅ ✅ ❌ 总结一句话就是,所有的功能型代码,都需要进行单元测试,但是像 UI 以及 css 等样式代码...,就不要进行不必要的测试了,意义其实并不大,除非你要写像 Ant Design 这类的 UI 库,在日常的业务场景下是完全没有必要。

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

40道ReactJS 面试问题及答案

这可确保在首次呈现组件进行一次 AJAX 调用。...使用验证器等库进行输入验证,并在用户输入呈现UI 中或在服务器上处理它们之前对其进行清理。 安全通信:使用 TLS/SSL 等安全通信协议在客户端和服务器之间传输敏感数据。...:为组件编写测试涉及使用 Jest 和 React 测试库等测试库来确保组件按预期运行。...这些测试可以单独检查每个组件的渲染、行为和状态。 让我们使用 Jest 和 React 测试库为此 Button 组件编写一些单元测试用例。...最后,我们断言使用正确的表单数据调用了handleSubmit 函数。 快照测试:快照测试是一种捕获组件输出“快照”并将其与先前存储的快照进行比较的方法。 使用 Jest 创建和维护组件输出的快照。

20510

如何自动化测试 React Native 项目 (下篇) - 单元测试

这种方法的特点是只 render 当前组件中一层深的元素, 不会去渲染当前组件中用到的子组件。 这就保证了测当前组件的时候, 不会受到子组件行为的影响。符合分层测试的需求;并且也比较快速。...Jest Snapshot Test的特点: Jest 使用一个 test renderer 来生成出 React tree 的序列化结构树。...对测试来说, 我们永远应该把注意力放在自己team写的代码上, 因此可以足够安全的认为当生成的 snapshot 正确组件UI渲染也是正确的。...组件交互测试 用 Enzyme shallow 生成的 ReactWrapper 会提供一些用来进行组件交互测试的 API,比如 find(), parents(), children()等选择器进行元素查找...这样的好处是当 PrimaryButton 自身出现bug, 之后这个组件本身的单元测试会 fail, 其他用到这个组件的 Component 并不会受影。 这样测试之间就相互独立了。

3.2K21

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

而对于开发者来说,重要的是进行测试的动作。本篇文章主要围绕着React组件单元测试展开的,其目的是为了让开发人员可以站在使用者的角度考虑问题。...这将用作查询的基本元素,以及在使用debug()打印的内容。•hydrate:用于服务端渲染,使用 ReactDOM.hydrate 加载你的组件。...除非合并,否则将覆盖DOM测试库中的默认设置。 基本上,这个函数所做的就是使用ReactDOM呈现组件。在直接附加到document.body的新创建的div中呈现(或为服务器端呈现提供水合物)。...这里,我们创建了自己的助手函数 renderWithRedux() 来呈现组件,因为它将被多次使用。 renderWithRedux() 作为参数接收要呈现组件、初始状态和存储。...接下来,我们使用render()来呈现组件并将存储传递给提供者。 也就是说,我们现在可以将组件 TestRedux 传递给 renderWithRedux() 来测试计数器是否等于0。

14.8K33

React + Redux Testing Library 单元测试

“知道”在结束进行断言。...其实组件化并不全是为了复用,很多情况下也恰恰是为了分治,从而我们可以分组件UI 页面进行开发,然后分别对其进行单元测试。...但与此同时,对 UI 渲染的组件进行测试依然存在一个问题,从下图中可以看出,越处于上层的组件,其复杂度必然会随之提高。...对于最底层的子组件来说,我们可以很容易得将其进行渲染并测试其逻辑的正确与否,但对于较上层的父组件来说,通常来说就需要对其所包含的所有子组件进行预先渲染,甚至于最上面的组件需要渲染出整个 UI 页面的真实...前端 UI 组件测试的最佳实践,使得我们可以使用它来更有效地测试组件

2.3K10

使用storybook管理React组件

本文已React的UI组件为例,演示如何新建/集成Storybook到项目中,并对UI组件进行全方位的管理,包括发布、demo文档、测试等。 1....测试UI组件 4.1 写测试用例的原因 找到bug 新修改没有改变已有的接口和功能 将测试用例作为文档 4.2 测试结构 使用storyshots插件来实现,其核心是使用Jest,原理是每次生成一份DOM...4.3 测试交互 storybook交互性测试可以使用 Enzyme来模拟用户输入,然后使用Mocha or Jest进行结果测试,storybook又一个专门的插件帮助我们集成他们:specifications...,通过断言来测试UI组件的属性,更多使用方法可以参考specifications插件的使用。...4.4 测试样式 样式测试这里采用Puppeteer 和Jest来实现,其原理是利用Puppeteer的无头的chrome浏览器和storybook的url绑定组件特点,来渲染不同的UI组件,再进行图片快照的对比

3.3K20

前端测试体系建设与最佳实践总结

单元测试:是指对软件中的最小可测试单元进行检查和验证,通常指的是独立测试单个函数。 UI 测试:是对图形交互界面的测试。 集成测试:就是测试应用中不同模块如何集成,如何一起工作,这和它的名字一致。...UI 测试 UI 测试尽管有官方的测试框架 ReactTestUtils 和 Test Render,但是它们的 API 比较复杂,官方文档也是推荐使用 react-testing-library 或...但是对于一些公共组件测试还是很有必要的,就像笔者前文说到过的一样,当项目的代码足够复杂,一个通用组件的改动迎接你的可能就是一个线上 Case。...在写某些模块的单测或是 UI 测试,大家可能会发现一些难以测试的点,比如 Localstorage, 或一些延时函数的触发。...只有单元测试UI 测试会计算到测试覆盖率,而 e2e 不会被计算进去。e2e 不需要写太多,因为大部分关键逻辑已经被单元测试覆盖,e2e 只需要简单的进行主流程的模拟。

5.3K30

Jest单元测试之旅—实践总结

而针对与我们前端来说,我认为单测就是:UI测试和逻辑测试,逻辑测试包含:工具类/函数、业务相关代码测试UI测试分为:公共组件和业务组件测试。 为什么要写单元测试?...对于UI层的多变上,我们应该尽量满足我们的公共方法和核心逻辑的测试覆盖,UI上若有强烈需求再进行覆盖,因为在业务开发中,UI上的单测投入回报率并不高且是多变的并不需要刻意为了单测而单测。...下面会根据各种场景进行分析 二、异步函数 在我们实际开发中我们会遇到很多异步函数,但是因为Jest进行测试,默认情况下一旦到达运行上下文底部当前测试立即结束,这样意味着测试将不能按照我们的预期进行,...这是因为Jest默认的超时时间为5秒,但是我们在进行测试不会真的等那么久,这时候Jest就提供了一系列工具方法解决该问题。...这里分别使用jest.spyOn和jest.Mock两个方式对同一个方法进行3种不同编写方式的测试,在实际情况中我们应该选择合适的方法。

10.2K20

对 React 组件进行单元测试

好的做法是使用stub 对它进行隔离替换。这样就实现了更准确的单元测试。...四个基础单词 编写单元测试的语法通常非常简单;对于jest来说,由于其内部使用了 Jasmine 2 来进行测试,故其用例语法与 Jasmine 相同。...fs 进行预处理读写等,灵活性非常高,可以很好的兼容各种项目 babel-jest 由于是面向src目录下测试其React代码,并且还使用了ES6语法,所以项目下需要存在一个.babelrc文件: {...作为UI组件,React组件中一些操作需要延时进行,诸如onscroll或oninput这类高频触发动作,需要做函数防抖或节流,比如常用的 lodash 的 debounce 等。..._modalClass = FakeReactBootstrapModal; } } 这样测试即可顺利进行,跳过了并不重要的 UI 效果,而各种逻辑都能被覆盖了 模拟fetch请求 在单元测试的过程中

4.2K40

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

('InteractionManager'); 六、Jest UI快照测试 Jest提供了snapshot快照功能用于UI测试,可以创建组件的渲染快照并将其与以前保存的快照进行比较,如果两者不匹配,则测试失败...快照将在测试文件的当前文件路径自动生成的snapshots文件夹中保存。当主动修改造成ui变化时,使用jest -u来更新快照。...这对于隔离组件进行纯单元测试很有用,效率高,可以进行模拟交互,并且从Enzyme 3开始也可以访问组件生命周期,所以一般组件测试用shallow即可。 mount:完整渲染,包括其子组件。..._onClear).toBeCalled();//测试组件实例上的方法是否被调用 九、Redux测试使用React或者React Native通常会使用Redux进行状态的管理,需要mock store...; 通过单元测试,给项目带来了不少好处: 通过单元测试可以确保代码得到预期的结果,在测试环境中就发现bug; 当修改依赖的组件,能在测试中发现被影响组件的错误,这样可以支持我们更好的重构代码,有利于项目的长期迭代

6K30

你需要了解的前端测试“金字塔”

但是它们无法测试一切。 为了确保我们呈现正确的样式,我们还需要使用快照测试。 快照测试 快照测试测试你的渲染组件的图片,并将其与组件的以前的图片进行比较。...用 JavaScript 编写快照测试的最好方法是使用 JestJest 不是拍摄渲染组件的图片,而是渲染组件标记的快照。 这使得 Jest 快照测试比传统快照测试快得多。...每次运行单元测试,都会重新生成一个快照,并将其与之前的快照进行比较。 如果代码改变,Jest 会抛出一个错误,并警告标记已经改变。 然后开发者可以手动检查没有类被误删的情况。...在下面的测试中,有人从中删除了 modal-card-foot 类。 快照测试是一种检查组件样式或标记的方法。 如果快照测试通过,我们知道代码更改不会影响组件的显示。...如果测试失败,那么我们知道确实影响了组件的渲染,并可以手动检查样式是否正确。 每个组件至少应有一次快照测试。 一个典型的快照测试呈现组件的状态,以检查它正确呈现

1.6K80

Jest + React Testing Library 单测总结

1.2 测试框架和 UI 组件测试工具 而说起前端的测试框架和工具,比较主流的 JavaScript 测试框架有 Jest、Jasmine、Mocha 等等,并且还有一些 UI 组件测试工具,比如 testing-libraray...测试框架和 UI 组件测试工具之间并不是相互依赖、非此即彼的,而是可以根据不同工具的性质做不同的搭配。...1.3 组件单测须知 在开始进行组件单测的时候,有几个因素我们需要考虑: 组件是否按照既定的条件 / 逻辑进行渲染 组件的事件回调是否正确 异步接口如何校验 异步执行完毕后的操作如何校验 .........的扩展阅读材料 Jest 学习指南 那些年错过的 React 组件单元测试 使用 Jest 测试 JavaScript (Mock 篇) 3、React Testing Library testing...   }); }); 其实,在我们编写组件测试用例,都可以通过 debug 函数把组件渲染结果打印出来,这可以提高我们编写用例的效率,同时,这一特点也很符合 RTL 的设计观念。

4.5K20

如何对第一个Vue.js组件进行单元测试 (上)

在本教程中,我们将使用Vue Test Utils——官方Vue.js测试工具包,以及Jest,一个由Facebook支持的JavaScript测试运行器。   ...Vue Test Utils允许您单独安装Vue组件并模拟用户交互。它有测试单个文件组件所需的所有实用程序,包括使用Vue Router或Vuex的实用程序。   ...单元测试的一种常见方法是仅关注公共API(也称为黑盒测试)。通过忽略实现细节,您可以在不必调整测试的情况下进行内部更改。毕竟,您要做的是确保您的公共API不会中断。...因此,我们只测试我们可以从组件外部访问的内容:   交互   道具变化   我们不会直接测试计算属性、方法或钩子(hooks)。这些将通过测试公共接口进行隐性测试。   ...确定测试方案   当我们从外部看评级,我们可以看到它在执行以下操作:   它呈现的stars列表等于用户传递的maxStars道具的属性;   它为每个star添加一个活动类,其索引值小于或等于用户传递的

2K20

手摸手教你封装跨项目复用的 Vue 组件

关于同一组件在不同项目中的区别方面,以一个二次封装 element-ui 中 el-date-picker 的 DateRange.vue 组件举例: 所在项目基础组件库发现的代表性问题A element-ui...仅以例子中的几个项目来说,维护点就在 6 个,工作量×6 如果 收敛到一个统一的库 中,则维护点变为 2 个,仅需区分基础版本库的差别 而大部分较简单的组件,基础组件库的版本不同并不会造成差异的,或是根本没有引用...element-ui 组件库的简单组件,则维护点直接能缩减到 1 个 什么样的组件是通用的?..."test": "jest" }, "pre-commit": [ "test" ], 这里用 pre-commit 包实现了提交前先进行单元测试的钩子功能。...不可避免的涉及到一些较通用的 UI组件/功能模块 的情况,将其集结后发布到 npm 上,并辅以完善的单元测试和可运行的 demo 展示、必要的文档,就能将维护组件的工作量大大减轻。

2.6K10

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

前言 ❝这篇文章是前端自动化测试系列的开始,自动化测试系列会从理论走向实践,真正带领大家学会使用前端自动化测试框架,并能在业务中落地。 看完整个系列,还不会使用自动化测试工具为生产提效,请来找我!...单元测试也应该是项目中数量最多、覆盖率最高的。」 能进行单元测试的函数/组件,一定是低耦合的,这也从一定程度上保证了我们的代码质量。...在前后端分离的开发模式中,前端开发通常会使用到 Mock 的服务器和数据。因而我们需要在开发基本完成后进行相应的 UI 测试UI Test)。...Augular 的默认测试框架就是 Karma + Jasmine,而 React 的默认测试框架是 JestJest 被各种 React 应用推荐和使用。...(甚至是不懂编程的)使用自然语言来描述系统功能和业务逻辑,从而根据这些描述步骤进行系统自动化的测试 Jest 基本语法 「由于大厂普遍使用 React/Vue 进行开发,而 React/Vue 官方推荐的单元测试工具都是

4.3K11
领券