Sinon spy callCount属性在某些测试中返回0

时间:2018-01-10 15:31:04

标签: javascript unit-testing sinon

这是我的代码:

// SUT.spec.js
import * as myModule from './myModule';

describe('my issue', () => {
  let myFuncSpy = sinon.spy(myModule, 'myFunc');

  beforeEach(() => {
    myFuncSpy.reset();
  });

  it('my case A', () => {
    SUT.methodA();

    expect(myFuncSpy.callCount).to.equal(1);  // fails, it says it's 0
  });

  it('my case B', () => {
    SUT.methodB();

    expect(myFuncSpy.callCount).to.equal(1);  // passes

  });
});

在我的模块中,两个方法调用myFunc,但仅在methodA上没有注册:

// SUT.js
import { myFunc } from './myModule';

export function methodA() {
  myFunc(....);
  console.log(myFunc.callCount); // Mocha output shows 1
};

export function methodB() {
  myFunc(....);
  console.log('method B ran');   // Mocha output shows this line
  console.log(myFunc.callCount); // Mocha output shows 1
};

基本上,调用间谍的方式没有明显差异。我很困惑,因为可能出错。

我在SUT中添加了console.log语句,以确保间谍正确设置(否则它将没有名为callCount的属性)。另外,如果我注释掉.reset()来电,则日志语句会显示undefined而不是1或其他号码。

这里可能有什么问题?这当然是实际SUT的简化版本。但是,console.log语句表明问题绝对不是没有执行这些行。

1 个答案:

答案 0 :(得分:1)

在断言之前,您必须等待异步方法。