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

用 jest 单元测试改善老旧的 Backbone.js 项目

本文将尝试用一个重构实例来抛砖引玉,讲解如何对其应用较新的 jest 测试框架,并用 ES6 class 等新手段升级 Backbone.View 视图组件和改善页面结构,希望能对类似项目的改善起到开启思路的作用...通常的 Backbone 项目也可以忽略文中涉及 react 的部分。 升级测试框架 和之前文章中的例子相同,本次依然采用 Jest 作为测试框架。...的单元测试并不严谨,依赖了提供 mock 数据的 php 服务器环境 三是由于视图层没有很好的组件化,从而缺乏对视图组件的测试 jest for Backbone 的实践 jest 是比较新的测试框架...总结 jest 灵活的配置能力,使其能方便的应用于各种类型既有项目的 TDD 开发和重构 之前的其他测试框架下的用例,可以快速迁移到 jest 中 Backbone.View 视图组件在经过 ES6 升级和合理封装后...组件引入的模板,也可以用 jest.doMock() 很好的支持 将单元测试任务加入原有的 build 工作流,可以保证相关代码之后的持续有效 (end)

3.5K10

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

因为有很多足够多优秀的的前端框架(比如 React,Vue 和 Angular);以及一些易用且强大的UI库(比如 Ant Design)为我们保驾护航,极大地缩短了应用构建的周期。...严重的时候甚至会出现我改了一行代码,却不清楚其影响范围情况。这种时候,就需要测试的方式,来保障我们应用的质量和稳定性了。 接下来,让我们学习下,如何给 React 应用写单元测试吧?...它只查看实现本身,也就是说,您的递增和递减方法执行之后,应用的状态是否正确。这就是代码损坏,测试也会通过。...测试计数器的增减是否正确: 为了测试递增和递减事件,我们将初始状态作为第二个参数传递给renderWithRedux()。现在,我们可以单击按钮并测试预期的结果是否符合条件。...测试当我们点击链接时,它是否用参数导航到其他页面: 现在,要检查导航是否工作,我们必须触发导航链接上的单击事件。

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

    五年 Web 开发者 star 的 github 整理说明

    node-ffmpeg ffmpeg视频处理的node库 bgrins/videoconverter.js 浏览器上转换和操作视频 pillarjs/multiparty node端解析请求中表单数据...airbnb/enzyme React的js测试工具 facebook/jest facebook的js测试库 dominictarr/event-stream 函数式的流处理IO库 mochajs...ElemeFE/element 饿了么前端团队的Vue组件库(业界比较早的vue组件库) ElemeFE/mint-ui 饿了么前端团队的移动端Vue组件库 Semantic-Org/Semantic-UI...UI组件库 visionmedia/page.js 前端路由器组件 websockets/ws 前端websocket工具库 alsotang/fast-js 如何编写高效率js的知识库,附测试代码...h5开发框架 devbridge/jQuery-Autocomplete 输入框自动完成的库 dyve/jquery-autocomplete 输入框自动完成的库 xdan/autocomplete

    8.9K50

    这个设计系统开源神器,让你的产品颜值与效率齐飞

    不同于普通UI库,它从设计工程化角度出发,打通Figma设计资源与前端代码的桥梁,真正实现设计稿到代码的"零误差还原"。目前已在字节跳动200+项目中验证,日均调用量超过3000万次。... );}智能组件生态组件类型代表组件特色功能数据展示Table/Chart/Carousel虚拟滚动支持百万级数据表单类Form/AutoComplete...Jest+React Testing Lib单元测试覆盖率95%+真实界面效果展示同类项目对比维度Semi DesignAnt DesignMaterial-UI设计资源同步✅ Figma插件❌ 仅PDF...:需要快速搭建中后台系统的团队对UI一致性要求严格的金融/电商项目追求设计品质的创业公司同类优秀项目推荐Arco Design(字节跳动):面向B端场景的完整解决方案TDesign(腾讯):微信生态深度整合的设计体系...Naive UI(个人开源):Vue3生态的轻量级选择立即体验https://github.com/DouyinFE/semi-design 官方文档:https://semi.design/zh-CN

    10110

    Jest + React Testing Library 单测总结

    1.2 测试框架和 UI 组件测试工具 而说起前端的测试框架和工具,比较主流的 JavaScript 测试框架有 Jest、Jasmine、Mocha 等等,并且还有一些 UI 组件测试工具,比如 testing-libraray...测试框架和 UI 组件测试工具之间并不是相互依赖、非此即彼的,而是可以根据不同工具的性质做不同的搭配。...目前腾讯课堂基于 Tdesign 开发的素材库组件的单测,就是使用 Jest + React Testing Library 来完成。...Jest Mock 的常用 API 是:jest.fn () 和 jest.mock ()。...   }); }); 其实,在我们编写组件测试用例时,都可以通过 debug 函数把组件渲染结果打印出来,这可以提高我们编写用例时的效率,同时,这一特点也很符合 RTL 的设计观念。

    4.6K20

    用Python测试InnoDB和MyISAM的读写性能

    数据科学俱乐部 中国数据科学家社区 本文测试所用工具版本如下: MySQL:5.7.18 Python:3.6 Pandas:0.23 一、创建数据表 首先我们需要把两张使用了不同引擎的表创建出来,...因为是简单操作,创建的具体细节就不详述了,至此,我们的数据库就把使用 InnoDB 和 MyISAM 两种引擎的表创建好了。...结论:单线程的情况下,MyISAM引擎的写入速度比InnoDB引擎的写入速度快88% 三、多线程写入性能对比 1、InnoDB 引擎 执行以下代码,往使用了InnoDB引擎的表格插入1000条数据 importandas...结论:多线程的情况下,MyISAM引擎的写入速度比InnoDB引擎的写入速度快42% 四、读取性能对比 为了获得数据量较大的表用于测试数据库的读取性能,我们循环执行10遍上面多线程写入数据的操作,得到两张数据量为...结论:MyISAM引擎和InnoDB引擎的读取速度无明显差异 五、总结 1、写入速度,MyISAM比InnoDB快,单线程的情况下,两者差异尤为明显 2、读取速度,InnoDB和MyISAM无明显差异

    1.1K30

    如何发布一个 TypeScript 编写的 npm 包

    前言 在这篇文章中,我们将使用TypeScript和Jest从头开始构建和发布一个NPM包。 我们将初始化一个项目,设置TypeScript,用Jest编写测试,并将其发布到NPM。...添加测试 作为一名负责任的开发,我们将从测试开始。我们将使用jest,因为它简单且好用。...npm i -D jest @types/jest ts-jest ts-jest包是Jest理解TypeScript所需要的。另一个选择是使用babel,这将需要更多的配置和额外的模块。...x) ); } 这个实现可以更好,但对我们来说重要的是,现在测试通过了。自己用npm t试试吧。...我不觉得要发布任何配置文件,也不觉得要发布源文件和测试文件。 我们可以做的一件事是使用.npmignore,列出所有我们不想发布的文件。

    2K20

    基于 KIF 的 iOS UI 自动化测试和持续集成

    客户端 UI 自动化测试是大多数测试团队的研究重点,本文介绍猫眼测试团队在猫眼 iOS 客户端实践的基于 KIF 的 UI 自动化测试和持续集成过程。...测试框架的选择 iOS UI 自动化测试框架有不少,其中 UI Automation 是 Apple 早期提供的 UI 自动化测试解决方法,用 JavaScript 编写测试脚本,通过标签和值的可访问性获得...Xcode 7发布后,Apple 提供了一种新的 UI 自动化测试解决方法——UI Testing,它基于 XCTest 测试框架,通过控件的可访问性来定位和获取控件,并提供了多种 UI 操作 API,...一般来说,可将用例按功能分成若干个用例集,每个用例集按校验点或者功能点分成若干个用例,这样方便测试用例的管理和维护。...因此,在我们的 UI 自动化测试中,我们选择核心功能的冒烟用例来完成持续集成中的测试金字塔。

    2.3K60

    对 React 组件进行单元测试

    ,对于某些不容易构造或者不容易获取的对象,用一个虚拟的对象来创建以便测试的测试方法 广义的讲,以上的 spy 和 stub 等,以及一些对模块的模拟,对 ajax 返回值的模拟、对 timer 的模拟,...四个基础单词 编写单元测试的语法通常非常简单;对于jest来说,由于其内部使用了 Jasmine 2 来进行测试,故其用例语法与 Jasmine 相同。...这个单词的伦敦读音为 ['enzaɪm],酵素或酶的意思,Airbnb 并没有给它设计一个图标,估计就是想取用它来分解 React 组件的意思吧。...React 单元测试常见案例 用例的预处理或后处理 可以用beforeEach和afterEach做一些统一的预置和善后工作,在每个用例的之前和之后都会自动调用: describe('test components..._modalClass = FakeReactBootstrapModal; } } 这样测试即可顺利进行,跳过了并不重要的 UI 效果,而各种逻辑都能被覆盖了 模拟fetch请求 在单元测试的过程中

    4.3K40

    storybook的介绍和使用 比较火的响应式UI开发及测试环境

    storybook是一套最近比较火的响应式UI 开发及测试环境。...有关,找了篇 文章,不了解的同学可以看下 根据官网介绍一个story是一个或多个UI组件的单一状态,基本上像一个可视化测试用例。...打开 这个,这是airbnb公司实现的一个react的datepicker组件。这个组件配置很多,怎么让大家直观的查看学习呢?...storybook本身提供了很多组件,也可以添加自己的组件作为story,方便他人查看,使用并测试。 使用storybook你需要有react或vue的开发经验,并且熟悉es6。...image.png 然后又多出来个名为.storybook的目录,里面有附件组件文件 addons.js 和 config.js 安装后根据提示执行 yarn run storybook 启动storybook

    3.1K40

    使用storybook管理React组件

    本文已React的UI组件为例,演示如何新建/集成Storybook到项目中,并对UI组件进行全方位的管理,包括发布、demo文档、测试等。 1....测试UI组件 4.1 写测试用例的原因 找到bug 新修改没有改变已有的接口和功能 将测试用例作为文档 4.2 测试结构 使用storyshots插件来实现,其核心是使用Jest,原理是每次生成一份DOM...PS:下次运行Jest时,只有DOM结构与上次完全一致测试才会通过,通常会有两种方法来解决这种情况: 找到问题,修复不同; 用新的DOM结构替换旧的。...4.4 测试样式 样式测试这里采用Puppeteer 和Jest来实现,其原理是利用Puppeteer的无头的chrome浏览器和storybook的url绑定组件特点,来渲染不同的UI组件,再进行图片快照的对比...4.5 手动测试 再好的自动化测试,都和人的体验存在差距,所以发布之前还是需要经过人眼测试,因为storybook活文档的特点,我们可以直接运行体验UI组件,通过交互操作、knobs插件等来进行全面体验

    3.4K20

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

    单元测试实践 组件UI测试 (Snapshot) 传统的 Snapshot 测试一般是渲染一个UI组件 -> 截取屏幕快照 -> 和之前的屏幕快照对比。...实际应用时,我们用了 jest 的 shallow 方法来生成测试组件的wrapper; 用 enzyme-to-json/serializer 这个 lib 把生成的 shallowWrapper 转化成...用 shallow 的好处是保证每个组件测试的独立性,比如在当前组件的 snapshot 结构树中, 我只关心我用到的 childComponent 的名字和传给他什么 prop, 具体这个组件的内部UI...我们的测试脚本可以这么写: // Mock Logger module中的方法, 用jest.fn来实现spy方法 Logger.log = jest.fn(); // setup shallowWrapper...和通常的 WWW API 测试的方法几乎相同。 用Jest实现的好处是保持所有的单元测试用统一的 framework 实现和运行, 用起来比较方便。

    3.3K21

    用JUnit和Byteman测试Spring中的异步操作

    BMUnit是一个软件包,通过将Byteman集成到两个最受欢迎的Java测试框架(JUnit和TestNG)中,可以很容易地将Byteman用作测试工具。...Bmunit-extension是GitHub上的一个小项目,其中包含junit4规则,该规则允许与Byteman框架集成并在JUnit和Spock测试中使用它。它包含一些辅助方法。...测试用例假设我们注册了一个新的应用程序用户(所有事务都已提交)并向他发送电子邮件。电子邮件发送操作是异步的。 现在,该应用程序只包含一些测试,这些测试显示了如何测试这种情况。...从Byteman的“开发人员指南”中,我们发现,在需要确保一个线程直到退出一个或多个相关线程之前不会继续运行的情况下,联接器很有用。 通常,在创建连接器时,我们需要指定需要连接的线程的标识和编号。...无需Byteman即可测试相同的测试用例,但需要更改源代码。

    1.8K10

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

    一、技术选型: Jest + Enzyme + react-hooks-testing-library 1.1 jest Jest是FaceBook出品的前端测试框架,适合用于React和React...有以下几个特点: 简单易用:易配置,自带断言库和mock库。 快照测试:能够创造一个当前组件的渲染快照,通过和上次保存的快照进行比较,如果两者不匹配说明测试失败。...1.2 Enzyme Enzyme是AirBnb开源的React测试工具库,通过一套简洁的api,可以渲染一个或多个组件,查找元素,模拟元素交互(如点击,触摸),通过和Jest相互配合可以提供完整的...('InteractionManager'); 六、Jest UI快照测试 Jest提供了snapshot快照功能用于UI测试,可以创建组件的渲染快照并将其与以前保存的快照进行比较,如果两者不匹配,则测试失败...快照将在测试文件的当前文件路径自动生成的snapshots文件夹中保存。当主动修改造成ui变化时,使用jest -u来更新快照。

    6.1K30

    前端单元测试,更进一步

    前端测试@2022 如果从 2014 年 Jest 的第一个版本发布开始计算,前端开发领域工程化的单元测试能力已经发展了八年有余。...Jest 集成了 Jasmine 等以往各种被证明有效的单元测试框架和断言等工具,也可以用来完成包含外部接口服务的集成测试等。...Storybook 则在浏览器环境中,为 UI 组件的单独编写和测试提供了可视化的、可交互的、与具体业务项目无关的单独运行环境;无论是 web 项目还是混合式的桌面应用,都可以不理会繁复的项目配置和依赖...在测试分层金字塔模型中,最终还需要立足真实业务项目的 UI 测试,也就是终端用户(或 QA 测试人员)到终端设备的 E2E(end to end) 测试。...较新版本的 Storybook 中引入了 交互式测试(Interaction Test) 的概念,用法也极为简单,只需要为既有的 UI 用例编写一个 play() 函数 就可以了。

    1.1K00

    前端自动化测试实践02—jest基本语法

    前端自动化测试实践02—jest基本语法 TOC Write By CS逍遥剑仙 我的主页: www.csxiaoyao.com GitHub: github.com/csxiaoyaojianxian...1. matchers 匹配器 测试工具中最基本的就是断言匹配器,下面是 jest 中常用的匹配器。...,作用域不同 describe('测试分组和钩子函数', () => { let counter = null // 外层 beforeEach beforeEach(() =>...、UI等内容的测试,快照保存上次运行的结果存储在 __snapshots__ 下,如果两次执行结果不一致则不通过,需要检查后更新快照,按 u 更新全部快照,按 i 进入交互式单独更新。...DOM 测试 dom 测试一般用于测试 UI,例如需要测试下面 jquery 操作 dom 的代码 dom.js import { jsdom } from 'jsdom' import $ from

    1.8K75

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

    Jest 是一款轻量的 JavaScript 测试框架,它的卖点是简单好用,由 facebook 出品。本文就简单讲讲如何使用 Jest 对 React 组件进行测试。 为什么需要单元测试?...单元测试(Unit Testing),指的是对程序中的模块(最小单位)进行检查和验证。比如一个函数、一个类、一个组件,它们都是模块。 使用单元测试的优点: 更好地交付高质量代码。...代码不可能没有 bug,测试能帮你找出来; 更容易重构。我们不愿意去重构代码,不去还技术债,很大原因是测试覆盖率不足,害怕遗漏一些边边角角的逻辑,导致线上发生重大事故; 可以用测试描述模块功能。...比如某个模块很难测试,是因为它和其他模块高度耦合,此时你需要替换为 依赖注入 的方式来管理模块依赖。...function sum(a, b) { return a + b; } export default sum; 然后我们用 Jest 来做测试。 import sum from '.

    2.9K20

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

    而针对与我们前端来说,我认为单测就是:UI测试和逻辑测试,逻辑测试包含:工具类/函数、业务相关代码测试。UI测试分为:公共组件和业务组件测试。 为什么要写单元测试?...它能带来的好处我总结有: 单测可以确保程序得到预期的结果,验证功能完备性 促使开发者写可测试的代码和整洁的代码结构,易测试的代码间接说明代码质量的好坏 提前发现Bug和边界值处理,降低风险 重构时能保证重构的正确性...测试可以作为其他开发人员理解代码行为的方式之一 因为作为业务开发且前端是作为和用户最近的一层,特别是交互和视觉上对于前端来说极其不稳定的。...对于UI层的多变上,我们应该尽量满足我们的公共方法和核心逻辑的测试覆盖,UI上若有强烈需求再进行覆盖,因为在业务开发中,UI上的单测投入回报率并不高且是多变的并不需要刻意为了单测而单测。...这里分别使用了jest.spyOn和jest.Mock两个方式对同一个方法进行3种不同编写方式的测试,在实际情况中我们应该选择合适的方法。

    10.3K20

    用Jest做前端单元测试

    就像测试领域里的 UI 自动化、自动化测试这些,听着很牛比其实应用场景不大,本身 UI 就是前端里变化最快的,今天是绿色背景,明天可能就改成红色的了,老板觉得字体太小,立即马上现在就得改成 60px 加粗...倒也不是说前端单元测试一无是处,对于我们平常的业务功能测试可能没啥用,但对于框架作者来说还是很有用的,在很多知名的框架代码里我们也都能看到专门的test测试目录。...市面上比较常见的前端单元测试 Jest、Mocha,各种对比 Jest 略胜一筹,所以下面就来初体验下 Jest 吧。...Jest 安装和使用直接新建个目录用 npm 安装就可以写个 demo 了,Jest 官方文档上也有教程。...通常而言,一个单元测试是用于判断某个特定条件(或者场景)下某个特定函数的行为,是针对软件的基本单元(如:函数)所做的测试,而集成测试则是以模块和子系统为单元进行的测试集成测试:Integration Test

    26320

    在 ts + Jest 单元测试中 debugging

    TS 写的 所测功能无 UI 界面,且出现 bug 初步定位到是循环体内部问题,功能较为复杂 用 console 式 debug 效率太低,需要打断点式调试 在 Jest 单测中进行 debugger...Jest运行测试用例的特点是多进程并发运行不同测试案例,达到快速的效果。但是这样对调试来说是没法进行的。这个参数保证了使用一个进程运行所有代码。 接下来就可以开心的 debug 了: ?...Jest:简要总结了用 Chrome 调试和 VSCode 调试,本文所用的 Chrome 调试 就是通过这篇文章学会的 debugging-jest-tests:微软官方仓库中给出的 VScode 中...launch.json 的配置项教程,涵盖了 debug 全部测试文件 和 debug 单个测试文件 这两种场景,足够了 Debugging TypeScript Jest Tests With Visual...Studio Code:文中给出针对 ts + jest 的 launch.json 的配置项,可以借鉴一下 使用jest+enzyme进行react项目测试 - debug篇:虽说是 2017 年的文章

    4K30
    领券