我如何在使用sinon的路由中添加内部函数

问题描述 投票:1回答:1

我有内部功能

//in greatRoute.ts
async function _secretString(param: string): Promise<string> {
   ...
}

router
  .route('/foo/bar/:secret')
  .get(
    async (...) => {
      ...
      const secret = _secretString(res.params.secret);
      ...
    },
  );

export default {
  ...
  _secretString
};

现在,我正在尝试使用sinon.stub这样的模拟通话:

sinon.stub(greatRoute, '_secretString').resolves('abc');

但是那并不是我想要的那样。当我在测试中调用路由时,它仍会进入_secretString函数。我在这里想念什么吗?我已经尝试将导出文件放在函数标头的前面,如下所示:export async function _secretString(param: string): Promise<string>而不是执行export default {...},但这没有帮助。

node.js typescript express sinon sinon-chai
1个回答
0
投票

您可以使用rewire程序包存根_secretString功能。例如:

index.ts

async function _secretString(param: string): Promise<string> {
  return 'real secret';
}

async function route(req, res) {
  const secret = await _secretString(req.params.secret);
  console.log(secret);
}

export default {
  _secretString,
  route,
};

index.test.ts

import sinon from 'sinon';
import rewire from 'rewire';

describe('61274112', () => {
  it('should pass', async () => {
    const greatRoute = rewire('./');
    const secretStringStub = sinon.stub().resolves('fake secret');
    greatRoute.__set__('_secretString', secretStringStub);
    const logSpy = sinon.spy(console, 'log');
    const mReq = { params: { secret: '123' } };
    const mRes = {};
    await greatRoute.default.route(mReq, mRes);
    sinon.assert.calledWithExactly(logSpy, 'fake secret');
    sinon.assert.calledWith(secretStringStub, '123');
  });
});

带有覆盖率报告的单元测试结果:

fake secret
    ✓ should pass (1383ms)


  1 passing (1s)

----------|---------|----------|---------|---------|-------------------
File      | % Stmts | % Branch | % Funcs | % Lines | Uncovered Line #s 
----------|---------|----------|---------|---------|-------------------
All files |      75 |      100 |      50 |      75 |                   
 index.ts |      75 |      100 |      50 |      75 | 2                 
----------|---------|----------|---------|---------|-------------------
© www.soinside.com 2019 - 2024. All rights reserved.