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

前端测试驱动开发模式(TDD)快速入门

为了可以方便执行单元测试,可以加一个npm scripts,在package.json的scripts中加入如下语句,表示使用mocha去执行test文件夹下的js测试: "scripts":{ "...test": "mocha test/**/*.js" } 复制代码 在test中建立一个js文件,在文件的中引入这些工具,为了连接sinon 和 chai,要使用到sinon-chai const chai...) const assert = chai.assert // 从chai中引出assert 复制代码 如何实施TDD 如何写一个单元测试 首先我们看一个简单的单元测试代码: describe('测试navigateTo...(badFn, 'this.commonDirectFn is not a function') // 再把包装后的函数传入throws }) 复制代码 使用sinon模拟函数 如果需要模拟一个函数...mocha,chai,sinon的一些高级的用法,还需要通过实践去学习。 另,本文只是对但纯js的测试,react,vue和小程序都有他们自己的ui测试的方案。

2.5K20

Vue 测试速成班

在本教程中,我将向你展示如何为 Vue 应用程序编写单元、集成和端到端测试。 有关更多测试示例,可以查看我的 Vue TodoApp 实现[1]。 1....安装完成后,package.json 中将出现下面几个附加依赖项: •@vue/cli-plugin-unit-mocha: 使用 Mocha[3] 进行单元/集成测试的插件•@vue/test-utils...Mocha 没有内置的断言库,所以我们必须使用 Chai :它可以设置对结果的期望。Chai 有许多不同的内置断言,但没有涵盖所有用例,缺失的断言可以通过 Chai 的插件系统导入。...这些伪实现可以捕获传递给它们的参数,并用我们要求它们返回的内容进行响应。我们没有为 commit 方法指定返回值,所以它将返回一个空值。...我们必须将 sinonChai 作为一个插件添加到 Chai 中,以便能够对调用签名进行断言。

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

    为ES6配置JavaScript测试工具

    你该如何为ES6代码编写单元测试呢?又该如何配置测试工具以支持这些新特性呢?...在加载Chai时,我们使用了const而不是var。这意味着我们不会在不经意间重新定义该变量,并且它明确表明了我们不希望修改它的意图。 我们还使用了箭头函数。...使用它,你可以在一定程度上简化代码,然而它也可能带来一些潜在的问题 —— 我会在后边的最佳实践章节讨论这一点。 最后,和加载Chai时一样,我们使用const声明了期望的结果变量。...在Mocha中谨慎使用箭头函数 在Mocha中请谨慎使用箭头函数。在某些情况下你需要使用this.timeout来控制一个测试在超时之前的等待时间。如果你使用了箭头函数,那这个配置就不会生效。...('error message'); }); 要了解更多信息,请参考我的文章JavaScript单元测试中的Promise:权威指南。

    3K20

    React 测试驱动教程

    Hello World Image 设置 Mocha,Chai,Sinon 和 Enzyme Mocha:将用于运行我们的测试。 Chai:是我们期待的库。...AirBnB 写的一个很漂亮的测试库。 安装这些包: npm i mocha chai sinon --save-dev 如果我们希望能够使用 ES6 编写测试,那么我们需要在运行前对代码进行转译。...接下来让我们测试一个组件的安装和调用函数,当它安装时,我们可以得到一些暴露在 sinon 上的信息和正在使用的 spies。...react 组件已经有了一个很好的理解了。...虽然我只使用 React 开发了数月,但我已经爱上它了。我希望本教程可以帮助你更深入地理解一些 React 测试的最佳实践。有任何问题或评论随时联系我。测试是我们的好朋友! 原文链接

    4.6K20

    使用mocha编写node服务单元测试

    命令添加参数,指定使用babel进行编译: mocha --require @babel/register 如果觉得命令行参数太多太长,mocha允许我们使用配置文件的方式来进行传参: module.exports...chai断言库 mocha可以搭配你喜欢的任何断言库,经常使用到的有chai断言库。 chai提供了多种风格语法去帮助我们判断函数的执行结果。...例如当我们需要对一个删除数据的接口进行测试时,我们不能真的去执行数据库删除操作来判断函数是否正常执行。这时候就需要引入sinon来帮助我们替换掉这些难以模拟的逻辑。...sinon.stub替换了db的query方法,并且控制了其返回值。...本身是一个比较简单的测试框架,在此基础上,我们使用一些npm包来加强我们的测试过程: nyc: 提供全面的测试覆盖率 chai: 多种风格的断言判断 sinon: 用于模拟或者替换难以测试的代码 superTest

    4K20

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

    我希望通过对这些工具的各自作用的掌握,了解完整的前端测试技术方案。前端单元测试的领域也很多,这里主要讲对于前端组件如何进行单元测试,最后会主要介绍下对于 React 组件的一些测试方法总结。...mocha jasmine mocha 是一个经典的测试框架(Test Framework),测试框架提供了一个单元测试的骨架,可以将不同子功能分成多个文件,也可以对一个子模块的不同子功能再进行不同的功能测试...所以使用 Karma + mocha +chai 即可搭建一个完整的浏览器端的单元测试工具链。...使用 Jest + Enzyme 对 React 进行单元测试 ?...另外测试 React组件除了 Enzyme 提供的操作, Jest 中还有很多其他有用的特性,比如可以 mock 一个 npm 组件的实现,调整 setTimeout 时钟等,真正进行单元测试时,这些工具也是必不可少的

    9.6K20

    Vue的自动化测试

    单元测试 代码的单元测试主要针对某些核心功能的某些函数进行测试。vue官方推荐是使用karma,mocha和chai等。karma并不是一个测试框架,也不是一个断言库。...Karma兼容Jasmine,Mocha和QUnit,可以集成mocha,webpack等功能,成为以Karma为平台的单元测试,官方选择的事mocha的测试框架和chai的断言库。...mocha本身只是一个单元测试框架,可以兼容第三方断言库,包括: should.js expect.js chai better-assert unexpected 在Vue开发框架中位于specs(...在测试框架中,describe,it, expect和sinon都是全局方法。 Chai Chai也就是一个非常简单的断言库,所谓的断言,就是预期某些执行结果符合你自己的要求。...} }) 端对端测试 单元测试更多是对某个组件或者js进行功能测试。端对端测试(e2e)用于模拟整个业务流程的进行自动化测试(填报,增删查改等)。

    1.9K50

    提高代码质量——使用Jest和Sinon给已有的代码添加单元测试

    现在,我们可以使用单元测试来提高自己的代码质量。下面,我将自己在使用Jest和Sinon.js配置和编写单元测试中的收获的经验和踩到的坑进行总结,根据从零开始配置和编写单元测试这一条线来进行分享。...而对于其他的测试框架如:Mocha或者Chai等,没有进行具体的了解,因此在这里不多做评价。 如何配置Jest与Sinon.js,从而编写单元测试?...编写单元测试 在本章中,我们会针对如何编写单元测试文件进行一个具体的讲解,其中包含: 同步函数测试 异步函数测试 HTTP测试 同时,我们会对当中使用到的Jest和Sinon.js的API会进行简单介绍...关于Jest是如何测试JavaScript代码以及Sinon是如何模拟XMLHttpRequest请求的,我们将会在后面几篇博客中给大家带来相关的源码解析,有兴趣的同学可以关注我,留意后续的文章。...附录 Jest Sinon.js ava ava关于配置解决webpack alias的issue Mocha Chai

    3.8K00

    Meteor开发指南 — Mantra核心组件

    本文介绍了Mantra的核心组件和它们如何共同发挥作用的。 关注客户端 Mantra非常关注客户端,因为那是你写大部分代码的地方。我们允许客户端缓存和连接器与服务端和远端数据层交互。...为了使用Mantra,你首先需要使用Meteor 1.3,它包含了一个ES2015模块系统的实现。 React 作为 UI 我们使用React作为Mantra的UI(表现层)。...它做了下面这些事情: 将states传递给UI组件 将actions传递给UI组件 在应用上下文中传入任何配置项和库函数 应用上下文 应用上下文能被所有actions和容器获取,所以这里是app中提供共享变量的地方...路由和组件加载 我们通常使用路由来在UI中加载组件。 这里有多种选择(例如,FlowRouter和React Router) 单一入口 在Mantra中,我们想要app变得可预测的。...你可以使用熟悉的工具,如Mocha, Chai和Sinon来进行测试。

    1K60

    前端自动化测试工具 overview

    && Jasmine Mocha 跟 Jasmine 是目前最火的两个单元测试框架,基本上目前前端单元测试就在这两个库之间选了,下面是这两个库的区别,大家可以根据自己的需求进行选择: mocha:...优点: 终端显示友好 灵活,扩展性好 缺点: 自身集成度不高(没有断言,spy,异步等),而且经常要配合Chai,Sinon等库使用 配置相对麻烦一点点 Jasmine: 优点: 集成度高,自带BBD...两者功能覆盖范围粗略可以表示为: Jasmine(2.x) === Mocha + Chai + Sinon - mockserver PS: 个人实际使用后觉得Chai和Sinon毕竟是专门做特定功能的框架...,用 Mocha + Chai + Sinon 这种方式会想对舒爽一点。.../ http://thejsguy.com/2015/01/12/jasmine-vs-mocha-chai-and-sinon.html http://blog.founddrama.net/2012

    2.3K110

    也来扯扯 Vue 单元测试

    希望文中的一些内容对于正准备做 Vue (其实也不仅限于 Vue) 单元测试的人能有所帮助。 为什么要做单元测试 作为一个程序员,单元测试或许是一个绕不开的坎。...如果在进行单元测试过程中发现自己的一些代码不方便进行测试,那么你可能需要重新审视这些代码,看是否有一些设计上不合理或者可以优化的地方。...同时也可能存在一些 BUG(自己就曾修复过一个 ?)。但目前总体来说已趋于稳定,推荐使用,需要留意其最新更改。 选择一个好用的断言库 通常是 chai,有时候结合 sinon 一起使用。...我大致做了下对比,粗略总结如下: 优点 一站式的解决方案 在使用 Jest 之前,我需要一个测试框架(mocha),需要一个测试运行器(karma),需要一个断言库(chai),需要一个用来做 spies...这会导致一些问题,例如,如果组件代码中有一些根据实际渲染后的属性值进行计算(比如元素的 clientWidth)就可能出问题,因为 jsdom 中这些参数通常默认是 0.

    1.8K30

    前端自动化测试工具 overview

    && Jasmine Mocha 跟 Jasmine 是目前最火的两个单元测试框架,基本上目前前端单元测试就在这两个库之间选了,下面是这两个库的区别,大家可以根据自己的需求进行选择: mocha:...优点: 终端显示友好 灵活,扩展性好 缺点: 自身集成度不高(没有断言,spy,异步等),而且经常要配合Chai,Sinon等库使用 配置相对麻烦一点点 Jasmine: 优点: 集成度高,自带BBD...两者功能覆盖范围粗略可以表示为: Jasmine(2.x) === Mocha + Chai + Sinon - mockserver PS: 个人实际使用后觉得Chai和Sinon毕竟是专门做特定功能的框架...,用 Mocha + Chai + Sinon 这种方式会想对舒爽一点。.../ http://thejsguy.com/2015/01/12/jasmine-vs-mocha-chai-and-sinon.html http://blog.founddrama.net/2012

    1.4K10

    对 React 组件进行单元测试

    作为一种经典的开发和重构手段,单元测试在软件开发领域被广泛认可和采用;前端领域也逐渐积累起了丰富的测试框架和最佳实践。 本文将按如下顺序进行说明: I. 单元测试简介 II....比如一个方法可能依赖另一个方法的执行,而后者对我们来说是透明的。好的做法是使用stub 对它进行隔离替换。这样就实现了更准确的单元测试。...React 单元测试中用到的工具 Jest 不同于"传统的"(其实也没出现几年)的 jasmine / Mocha / Chai 等前端测试框架 -- Jest的使用更简单,并且提供了更高的集成度、更丰富的功能...” , 这也是 TDD 中的一般性步骤: 添加一个测试 运行所有测试,看看新加的这个是不是失败了;如果能成功则重复步骤1 根据失败报错,有针对性的编写或改写代码;这一步的唯一目的就是通过测试,先不必纠结细节...优化依赖 让 React 组件变得 testable 合理编写组件化的 React,并将足够独立、功能专一的组件作为测试的单元,将使得单元测试变得容易; 反之,测试的过程让我们更易厘清关系,将原本的组件重构或分解成更合理的结构

    4.3K40

    前端单元测试总结_javascript单元测试

    有测试用例做后盾,就可以大胆的进行重构 2.前端相关的单元测试技术 2.1 测试框架 目前,前端的测试框架很多,像QUnit、jasmine、mocha、jest、intern等框架,这些框架各有特点,...assert === 'object' chai.should(); // 对Obejct.prototype进行拓展 should.js: TJ的另外一个开源贡献 expect.js:BDD风格的另外一个断言库...sinon.js: 目前使用最多的mock库,将其分为spies、stub、fake XMLHttpRequest、Fake server、Fake time几种,根据不同的场景进行选择。...3.单元测试技术的实现原理 测试框架:判断内部是否存在异常,存在则console出对应的text信息 断言库:当actual值与expect值不一样时,就抛出异常,供外部测试框架检测到,这就是为什么有些测试框架可以自由选择断言库的原因...return proxy; } var proxy = spy(fn); // 得到一个mock函数 4.如何写单元测试用例 4.1原则 测试代码时,只考虑测试,不考虑内部实现 数据尽量模拟现实

    1.5K20

    实例入门 Vue.js 单元测试

    作为一个以 文档丰富 而广为人知的前端开发框架, Vue.js 的官方文档中分别在《教程-工具-单元测试》、《Cookbook-Vue组件的单元测试》里对 Vue 组件的单元测试方法做出了介绍,并提供了官方的单元测试实用工具库...本文作为《对 React 组件进行单元测试》一文的姊妹篇,将照猫画虎式的尝试面对初学和向中级进阶的开发者,对单元测试在 Vue.js 技术栈 中的应用做出入门介绍。 I....比如一个方法可能依赖另一个方法的执行,而后者对我们来说是透明的。好的做法是使用stub 对它进行隔离替换。这样就实现了更准确的单元测试。...Vue.js 中的单元测试工具 2.1 Jest 不同于"传统的"(其实也没出现几年)的 jasmine / Mocha / Chai 等前端测试框架;Jest的使用更简单(也许就是这个单词的本意“俏皮话...一个 无法测试 或 难以测试 的组件,基本上就等同于 设计得很拙劣 的组件. 组件之所以难以测试,是因为其有太多的 props、依赖、引用的模型和对全局变量的访问 -- 这都是不良设计的标志。

    2.9K20

    React风格的企业前端技术

    项目团队里如果很多是从后端转为前端的,可能Augular更加合适,如果大家都是以JS为中心的开发人员,那么React可能更加合适。 前端框架有了,还得配合成熟的测试框架才能保证产品质量。 ?...可以选择Karma作为Test Runner,Mocha/Chai作为测试类库(类似后端Junit),Sinon作为Mock类库(类似后端Mockito),结合不同的Karma Launchers来测浏览器的兼容性问题...运行单元测试 3. 资源压缩、合并 4. 资源懒加载 大家可以看到,从搭建到开发再到构建,还是做了很多事情的,一个流畅的工作流程必不可少。 ?...三、The Platform的React实践 ? (The Platform里前端的总体架构图) 框架 我们使用了React + Redux + React Router作为前端框架。...使用Karma+Mocha+Chai+Sinon作为测试框架,保证代码质量。

    98950

    2016 JavaScript 技术栈展望

    Mocha + Chai + Sinon 在 JavaScript 中,有大量可选的单元测试工具,每一个都很稳定和健壮。如果你只是用于单元测试,那么现有工具完全可以胜任你的需求。...我喜欢 Chai 断言是因为其种类丰富、功能齐全的插件,喜欢 Mocha 是因为其对异步的良好支持。强烈建议使用 Dirty Chai 避免某些问题。...我非常钟爱 Mocha 的特性,如果你想要的只是最基础的功能,可以参考这篇文章了解一下 Tape。...我不认为上述有一个完美的解决方案,但我对 API 有一个自己的认知: 可预测,遵循一致性协议 支持在一次查询中获取多个实体 支持更新操作 易于调试 易于使用 到目前为止,我还没有发现满足上述所有条件的解决方案...如果你的应用程序只有两三屏,那么就无需使用路由系统;如果你正在创建一个单页应用,那么甚至不需要 Redux,只需要 React 自己的 state 属性即可;如果你正在创建一个简单的 CRUD 程序,那么你就不需要使用

    2.1K40

    用不了多久 Web Component,就能取代你的前端框架吗?

    组件的所有样式都被定义在style标签内,如果你想使用一个常规的标签,你也可以获取外部样式。除此之外,还可以使用:host选择器对组件本身进行样式设置。...如果你希望用户可以设置组件的部分样式,你可以暴露CSS变量去达到这个效果。例如你想让用户可以选择组件的背景颜色,可以暴露一个叫 —background-color的CSS变量。...除了Mocha,这个设置还加载了WebcomponentsJS polyfill,Chai用于断言,以及Sinon用于监听和模拟。 mocha"> 在加载完所需的scripts后,我们暴露chai.assert作为一个全局变量,因此我们可以在测试中简易的使用...虽然我想这是真的,但是我认为这种好处是相当有限的。 我曾今用过Angular、React和Polymer做过很多项目。虽然大家都对它们很熟悉,但是尽管使用了相同的框架,这些代码库还是有很大的不同。

    2.3K40

    【Web技术】264- Web Component可以取代你的前端框架吗?

    组件的所有样式都被定义在style标签内,如果你想使用一个常规的标签,你也可以获取外部样式。除此之外,还可以使用:host选择器对组件本身进行样式设置。...如果你希望用户可以设置组件的部分样式,你可以暴露CSS变量去达到这个效果。例如你想让用户可以选择组件的背景颜色,可以暴露一个叫 --background-color的CSS变量。...除了Mocha,这个设置还加载了WebcomponentsJS polyfill,Chai用于断言,以及Sinon用于监听和模拟。 mocha"> 在加载完所需的scripts后,我们暴露chai.assert作为一个全局变量,因此我们可以在测试中简易的使用...虽然我想这是真的,但是我认为这种好处是相当有限的。 我曾今用过Angular、React和Polymer做过很多项目。虽然大家都对它们很熟悉,但是尽管使用了相同的框架,这些代码库还是有很大的不同。

    2.6K30
    领券