我正在用 sinon 来存根属性。我无法理解相关间谍活动的运作方式。大多数 sinon 间谍方法似乎与函数调用有关,而不是与对象属性的访问有关。作为解决方法,我创建了一个变量来跟踪属性访问,并在调用相关 getter 函数时手动设置它。请参阅下面的代码示例。这似乎工作得很好,但我觉得我可能复制了 sinon 中已经存在的一些功能。达到相同结果的更惯用的方法是什么?
const sinon = require('sinon');
const lib = require('./lib');
const app = require('./app');
const sandbox = sinon.createSandbox();
let fooAccessed = false;
sandbox.stub(lib, 'foo').get(() => {
fooAccessed = true;
return 123
});
app();
expect(fooAccessed).toEqual(true);
我知道这可能不是你想要的答案,因为我不使用“sinon”,但无论如何我都会回答。也许这对您有任何帮助。
您可以使用 Proxy 对象来拦截对对象的访问。
const obj = {
foo: "bar",
baz: true
};
let accessed = false;
const proxied = new Proxy(obj, {
get(target, prop) {
if (prop === "foo") {
accessed = true;
}
return target[prop];
}
});
console.log(proxied, accessed);
console.log(proxied.foo);
console.log(proxied, accessed);
结果:
{ foo: 'bar', baz: true } false
bar
{ foo: 'bar', baz: true } true
这是实现类似结果的惯用方法:
fooSpy = sinon.spy(lib, 'foo', ['get']);
然后
expect(fooSpy.get).to.have.been.called;
对于设置者来说也是如此,例如:
fooSpy = sinon.spy(lib, 'foo', ['set']);
然后
expect(fooSpy.set).to.have.been.called;
甚至
expect(fooSpy.set).to.have.been.calledWith(appropriate_value_here);