Sinon.place vs sinon.stub只是为了替换返回值吗?

本教程将介绍Sinon.place vs sinon.stub只是为了替换返回值吗?的处理方法,这篇教程是从别的地方看到的,然后加了一些国外程序员的疑问与解答,希望能对你有所帮助,好了,下面开始学习吧。

Sinon.place vs sinon.stub只是为了替换返回值吗? 教程 第1张

问题描述

在使用sinon时,我只想替换函数的返回值,而不需要其他信息,比如它被调用了多少次。哪一个更好?

sinon.replace(Component.prototype, 'getValue', () => 123);
const myStub = sinon.stub(Component.prototype, 'getValue');
myStub.return(123);

推荐答案

我很少看到sinon.replace在很多项目中使用。使用stub的好处是您可以多次修改返回值。

let getValueStub;

before(function() {
getValueStub = sinon.stub(Component.prototype, 'getValue');
})

after(function() {
sinon.restore();
})

it('test case A if return value is 123', function() {
getValueStub.returns(123);
// do expectation
})

it('test case B if return value is 234', function() {
getValueStub.returns(234);
// do expectation
})

同时,对于replace,根据sinon文档,您只能使用一次。

Sandbox.place(对象,属性,替换);

用替换参数替换对象上的属性。试图
替换已替换的值会导致异常。

替换可以是任何值,包括间谍、存根和假货。

例如:

sinon.replace(Component.prototype, 'getValue', function () {
  return 123;
});

sinon.replace(Component.prototype, 'getValue', function () { // this will return error
  return 456;
});

将返回错误

TypeError: Attempted to replace getValue which is already replaced

您可能可以通过将函数替换为存根来实现与存根相同的功能,sinon.replace

getValueStub = sinon.stub(); 
sinon.replace(Component.prototype, 'getValue', getValueStub);

getValueStub.returns(123); 
getValueStub.returns(456);

但是,由于简单,我更喜欢使用sinon.stub

引用:

好了关于Sinon.place vs sinon.stub只是为了替换返回值吗?的教程就到这里就结束了,希望趣模板源码网找到的这篇技术文章能帮助到大家,更多技术教程可以在站内搜索。