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

单元测试初体验

断言库 Chai Chai 是一个针对 Node.js 浏览器的行为驱动测试测试驱动测试的断言库,可与任何 JavaScript 测试框架集成。...测试辅助工具 Sinon Sinon 是一个独立的 JavaScript 测试 spy, stub, mock库,没有依赖任何单元测试框架工程。...Sinon API 介绍 辅助工具库 Sinon 主要有三个Api:spy, stub, mock spy 翻译过来的意思是 “监视”。...sinon.jsspy 主要用来监视函数的调用情况,sinon 对待监视的函数进行 wrap 包装,因此可以通过它清楚的知道,该函数被调用过几次,传入什么参数返回什么结果,甚至是抛出的异常情况。...var spy = sinon.spy(orginObj, 'launch'); spy.restore(); 当 spy 使用完成后,切记把它恢复成原始函数,就像上边例子中最后一步那样。

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

    实例入门 Vue.js 单元测试

    var spy = sinon.spy(MyComp.prototype, 'someMethod'); ......expect(spy.callCount).toEqual(1); 1.7 stub 有时候会使用stub来嵌入或者直接替换掉一些代码,来达到隔离的目的 一个stub可以使用最少的依赖方法来模拟该单元测试...虽然 Jest 本身也有一些实现 spy 等的手段,但 sinon 使用起来更加方便。...2.3 Vue Test Utils Vue Test Utils 是 Vue.js 官方的单元测试实用工具库;该工具库使用起来用以测试 React 组件的 Enzyme 工具库非常相似 它模拟了一部分类似...jQuery 的 API,非常直观并且易于使用学习,提供了一些接口几个方法来减少测试的样板代码,方便判断、操纵遍历 Vue Component 的输出,并且减少了测试代码实现代码之间的耦合。

    2.9K20

    前端自动化测试工具 overview

    前端测试化工具简单汇总和比较 Qunit jquery出的自动化测试库,没什么好说的,可以想象其跟jquery UI及jquery animation等库结局一样,逃脱不了各种被后来的库全方位的比较“...是目前最火的两个单元测试框架,基本上目前前端单元测试就在这两个库之间选了,下面是这两个库的区别,大家可以根据自己的需求进行选择: mocha: 优点: 终端显示友好 灵活,扩展性好 缺点: 自身集成度不高(没有断言,spy...,异步等),而且经常要配合Chai,Sinon等库使用 配置相对麻烦一点点 Jasmine: 优点: 集成度高,自带BBD,spy,方便的异步支持(2.0) 配置方便 缺点: 相对不太灵活 由于各种功能内建...两者功能覆盖范围粗略可以表示为: Jasmine(2.x) === Mocha + Chai + Sinon - mockserver PS: 个人实际使用后觉得ChaiSinon毕竟是专门做特定功能的框架...,用 Mocha + Chai + Sinon 这种方式会想对舒爽一点。

    2.3K110

    p6spy mysql8_P6Spy配置使用

    P6Spy是一个可以用来在应用程序中拦截修改数据操作语句的开源框架。 通过P6Spy我们可以对SQL语句进行拦截,相当于一个SQL语句的记录器,这样我们可以用它来作相关的分析,比如性能分析。...P6SPY提供了如下几个功能: 记录SQL语句的执行时间戳。...记录SQL语句类型 记录SQL填入参数的没有填入参数的SQL语句 根据配置的时间控制SQL语句的执行时间,对超出时间的SQL语句输出到日志文件中 下面是p6spy在应用程序上集成的步骤: (2)解压出...p6spy.jar spy.properties两个文件 (3)将p6spy.jar 放入应用程序的WEB-INF/lib目录,将spy.properties放入WEB-INF/classes目录 如果是...maven环境,p6spy.jar不用放到lib下,采用maven方式引入即可 p6spy p6spy 3.0.0 (4)修改spy.properties driverlist=com.mysql.jdbc.Driver

    80530

    前端自动化测试工具 overview

    前端测试化工具简单汇总和比较 Qunit jquery出的自动化测试库,没什么好说的,可以想象其跟jquery UI及jquery animation等库结局一样,逃脱不了各种被后来的库全方位的比较“...是目前最火的两个单元测试框架,基本上目前前端单元测试就在这两个库之间选了,下面是这两个库的区别,大家可以根据自己的需求进行选择: mocha: 优点: 终端显示友好 灵活,扩展性好 缺点: 自身集成度不高(没有断言,spy...,异步等),而且经常要配合Chai,Sinon等库使用 配置相对麻烦一点点 Jasmine: 优点: 集成度高,自带BBD,spy,方便的异步支持(2.0) 配置方便 缺点: 相对不太灵活 由于各种功能内建...两者功能覆盖范围粗略可以表示为: Jasmine(2.x) === Mocha + Chai + Sinon - mockserver PS: 个人实际使用后觉得ChaiSinon毕竟是专门做特定功能的框架...,用 Mocha + Chai + Sinon 这种方式会想对舒爽一点。

    1.4K10

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

    现在,我们可以使用单元测试来提高自己的代码质量。下面,我将自己在使用JestSinon.js配置编写单元测试中的收获的经验踩到的坑进行总结,根据从零开始配置编写单元测试这一条线来进行分享。...Sinon.js是一个用来做独立测试模拟的JavaScript库。它在单元测试的编写中通常用来模拟HTTP等相关请求。...; 在我的项目中,主要是使用Sinon.js来模拟HTTP请求。...编写单元测试 在本章中,我们会针对如何编写单元测试文件进行一个具体的讲解,其中包含: 同步函数测试 异步函数测试 HTTP测试 同时,我们会对当中使用到的JestSinon.js的API会进行简单介绍...,如果需要使用其他的API,可以自行阅读JestSinon.js的文档。

    3.8K00

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

    React.js作为前端框架的后起之秀,却在2015年携着虚拟DOM、组件化、单向数据流等利器,给前端UI构建掀起了一波声势浩大的函数式新潮流。...使用Enzyme简化测试代码 我们常常会提到,测试代码对于复杂代码库的可维护性至关重要,但是测试代码本身的易于理解编写,以及可读性可维护性也同等重要。...it('simulates click events', () => { const onButtonClick = sinon.spy() const wrapper = shallow(...则是一个可以用来MockStub数据代码的第三方测试工具库,当我们需要检查一个组件当中某个特定的函数是否被调用时,我们可以使用sinon.spy()方法监视所传入该组件作为prop的onButtonClick...总结 上一期技术雷达中指出:我们非常享受Enzyme为React.js应用提供的快速组件级UI测试功能。

    2.4K40

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

    : Behavior-Drive development(BDD)风格的测试框架,在业内较为流行,功能很全面,自带asssert、mock功能 mocha: node社区大神tj的作品,可以在nodebrowser...: TJ的另外一个开源贡献 expect.js:BDD风格的另外一个断言库,基于should.js,是mini版的BDD库 assert(node自带核心模块): 可以在node中使用的断言模块 2.3...sinon.js: 目前使用最多的mock库,将其分为spies、stub、fake XMLHttpRequest、Fake server、Fake time几种,根据不同的场景进行选择。...return proxy; } var proxy = spy(fn); // 得到一个mock函数 4.如何写单元测试用例 4.1原则 测试代码时,只考虑测试,不考虑内部实现 数据尽量模拟现实...,越靠近现实越好 充分考虑数据的边界条件 对重点、复杂、核心代码,重点测试 利用AOP(beforeEach、afterEach),减少测试代码数量,避免无用功能 测试、功能开发相结合,有利于设计代码重构

    1.5K20

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

    官网:mochajs.org github: github.com/mochajs/moc… chai.js chai 主要提供了断言函数assert,用来断言和比较测试的结果代码执行的结果。...为了可以方便执行单元测试,可以加一个npm scripts,在package.json的scripts中加入如下语句,表示使用mocha去执行test文件夹下的js测试: "scripts":{ "...test": "mocha test/**/*.js" } 复制代码 在test中建立一个js文件,在文件的中引入这些工具,为了连接sinon chai,要使用sinon-chai const chai...sinon模拟函数 如果需要模拟一个函数,可以用sinon去模拟,使用方法:sinon.fake(),并且课已通过这个sinon的called方法判断函数是否被执行。...mocha,chai,sinon的一些高级的用法,还需要通过实践去学习。 另,本文只是对但纯js的测试,react,vue小程序都有他们自己的ui测试的方案。

    2.5K20
    领券