资讯专栏INFORMATION COLUMN

Sinon

since1986 / 3118人阅读

摘要:完成后一定要否则会影响其他的测试的作用在于可以监视一个函数被调用的情况。在中用于对一个的活动进行监视。而出的收到了数据或是调用并没有真正执行,一切针对的调用都是假的。对相关的测试也提供了模拟功能。

Sinon.js是个测试辅助工具,在为Node程序写测试时可能可以派上用场。 在测试领域有这么几个基本名词:spy, stub, mock,这三个概念都是测试所用到的手段。Sinon.js就提供了相应的工具来实现这三种测试手段。

sinon.stub() 完成后一定要sinon.restore(),否则会影响其他的测试

spy

spy的作用在于可以监视一个函数被调用的情况。spy相当于给我们感兴趣的函数加了一层wrapper,于是记录下了这个函数被调用过几次,每次传入的参数是什么以及每次返回的结果是什么,或是抛出了怎样的异常。

var sinon = require("sinon");
sinon.spy(crawler, "launch"); // 监视crawler.launch,这是个function

// 对crawler.launch进行调用

crawler.launch.callCount > 1; // 该函数的调用次数
crawler.launch.withArgs("...").calledOnce; // 该函数是否以...参数调用过一次

crawler.launch.restore(); // 消除监视(测完换回去)
stub

测试中有可能遇到这样的情形:测试函数f1,f1依赖于函数f2,我们需要测试f1在f2的不同表现之下有怎样的表现。但是让f2有不同的表现可能会很不容易,有可能需要复杂的配置或是精巧的捏造,或是f2出现某种表现的几率很小等等。这时stub就可派上用场,stub就是人为设定的f2的替代品。我们可以设定stub在怎样的输入下有怎样特定的表现,从而不再阻碍对f1的测试。

var sinon = require("sinon");

var stub = sinon.stub(); // 创建一个stub
var stub = sinon.stub(ab, "f"); // 将ab.f替换成一个stub,使用完毕后需要调用stub.restore()或ab.f.restore()来复原
var stub = sinon.stub(ab, "f", function(...) {...}); // 将ab.f替换成指定的函数

stub.returns(10);
stub(); // stub()总是返回10

stub.throws("...");
stub(); // stub()总是抛出"..."

stub.withArgs(1).returns(10);
stub(1); // stub(1)会返回10

stub.restore();

在Sinon.js中,stub本身也是个spy,所以可以在stub上调用之前提到的 .callCount 等查看函数调用情况。

mock

mock在Sinon.js中用于对一个object的活动进行监视。一个object被mock以后,就可以设定我们对这个object有怎样的预期。这里的预期例如:某方法被调用了多少次(或至少至多多少次)、某方法一定没被调用、某方法被输入怎样的参数来调用、等等。可以看出mock对一个object的监视类似于spy对一个函数的监视。两者的关键区别在于使用场景,spy客观地监视了一个函数的表现,对这个函数的调用都真正执行了。而mock出的object收到了数据或是调用并没有真正执行,一切针对mock的调用都是假的。所以mock可以用来测试具有side effect的函数,这里的side effect泛指和外部对象有数据交互或者是调用,比如调用外部对象的方法、向server发送数据、和UI对象有交互、写日志等等。

var sinon = require("sinon");

var obj = {
  ...
};

var mock = sinon.mock(obj);
mock.expect("f").atLeast(2).withArgs(10); // obj.f(10)调用至少出现过2次

...

mock.verify(); // 测试此时的obj是否满足上面的mock设定条件
mock.restore();
其他问题

Sinon.js提供了模拟时间流逝的功能,但似乎并不好用。对于定时事件的触发会产生怎样的影响,还是先写点测试代码看清楚结果再用为好。

Sinon.js对Ajax call相关的测试也提供了模拟功能。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/92610.html

相关文章

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

    摘要:现在,我们可以使用单元测试来提高自己的代码质量。它在单元测试的编写中通常用来模拟等相关请求。通过这篇文章,你应该学会了如何针对已有代码从零开始编写一套完整的单元测试用例。 概述 在日常的功能开发中,我们的代码测试都依赖于自己或者QA进行测试。这些操作不仅费时费力,而且还依赖开发者自身的驱动。在开发一些第三方依赖的库时,我们也没有办法给第三方提供完整的代码质量报告。 现在,我们可以使用单...

    voyagelab 评论0 收藏0
  • 如何使用 mocha 和 sinon 集成单元测试--单元测试示例及分析(上)

    摘要:使用集成单元测试上项目地址安装依赖测试框架可视化报表覆盖率替换依赖断言命令命令命令执行单元测试,并打开测试报告页面和覆盖率页面执行生成单元测试覆盖率并打开执行单个单元测试文 使用 mocha 集成单元测试(上) 项目地址:https://github.com/Jay-tian/j... 安装依赖 yarn add jquery mocha mochawesome istanbu...

    Caicloud 评论0 收藏0
  • 【Node Hero】9. Node.js 单元测试

    摘要:基本上,测试金字塔描述你应该编写单元测试集成测试和端到端测试。集成测试要比端到端测试多,单元测试甚至要更多一些。应用程序单元测试编写单元测试,是为了看看给定的模块单元是否工作。 本文转载自:众成翻译译者:网络埋伏纪事链接:http://www.zcfy.cc/article/1754原文:https://blog.risingstack.com/node-hero-node-js-un...

    104828720 评论0 收藏0
  • mocha、chai、sinon和istanbul实现100%单元测试覆盖率

    摘要:加上测试覆盖率检查,就能够提供足够的信息,来断言代码的行为是否符合期望。测试的相关技术是程序的代码覆盖率工具,以土耳其最大城市伊斯坦布尔命名。 showImg(https://segmentfault.com/img/remote/1460000010260434); 敏捷软件开发中,最重要实践的就是测试驱动开发,在单元测试层面,我们试着实现一个重要的指标就是测试覆盖率。测试覆盖率衡量...

    Yuanf 评论0 收藏0
  • 使用karma+mocha+chai+sinon+@vue/test-utils为你的组件库增加单元

    摘要:但是,项目中的一些公共封装,比如公共的组件公用的功能模块等是可以使用单元测试的。因此特为组件库引入单元测试,目的在于能减少组件的,避免重复的发布不必要的包。 项目github地址:https://github.com/yuanalina/installAsRequired这里必须要提前说明,前端项目的单元测试不是必须的,特别是业务型项目,增加单元测试反而会成为累赘,增加开发成本且无意义...

    happen 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<