与Sinon一起监视财产变化

问题描述 投票:0回答:2

我正在用 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);
javascript sinon stubbing
2个回答
0
投票

我知道这可能不是你想要的答案,因为我不使用“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

0
投票

这是实现类似结果的惯用方法:

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);
© www.soinside.com 2019 - 2024. All rights reserved.