柴间谍和异步呼叫一次都没有呼叫



我正在构建一个应用程序,我需要在其中测试快速回调解析中的一些回调行为。

实际上,它看起来像:

const callbackRender = (httpResponse, response) => {
  console.log(httpResponse) // logs the good httpResponse object
  if (httpResponse.content.content) response.send(httpResponse.content.content)
  else response.render(httpResponse.content.page)
}
const callback = (injector, route) => {
  return (request, response) => {
    const ctrl = injector.get(route.controller)
    const result = ctrl[route.controllerMethod](new HttpRequest())
    if (result.then) {
      return result.then(res => callbackRender(res, response))
    } else {
      callbackRender(result, response)
    }
  }
}

两个失败的测试如下所示:

it('should call the callback render method when httpResponse is a promise', (done) => {
      const mock = sinon.mock(injector)
      const ctrl = new UserControllerMock()
      const routes = routeParser.parseRoutes()
      mock.expects('get').returns(ctrl)
      const spy = chai.spy.on(callbackRender)
      callback(injector, routes[3])(request, response).then((res) => {
        expect(spy).to.have.been.called.once
        mock.verify()
        mock.restore()
        done()
      })
    })
    it('should call the callback render method when httpResponse is not a promise', () => {
      const mock = sinon.mock(injector)
      const ctrl = new UserControllerMock()
      const routes = routeParser.parseRoutes()
      mock.expects('get').returns(ctrl)
      const spy = chai.spy.on(callbackRender)
      callback(injector, routes[1])(request, response)
      expect(spy).to.have.been.called.once
      mock.verify()
      mock.restore()
    })

似乎 chai-spies 无法检测到我的 callbackRender 函数在回调方法中被调用。

事实是,当我记录我的方法时,每次我需要它时,我都会传递它。

有人有想法吗?

编辑:之前的请求/响应定义每个

 beforeEach(() => {
    request = {
      body: {},
      params: {},
      query: {}
    }
    response = {
      send: () => {
      },
      render: () => {
      }
    }});

Spies/stubs/mocks 只有在它们可以替换原始函数(带有包装版本)显式传递(代码中并非如此)的情况下才能工作。

在您的情况下,callbackRender不会被替换(由于const,它不能被替换,但也因为它没有可以替换的"父"对象),因此任何将调用它的代码(如callback)都将调用原始函数,而不是间谍。

解决方案取决于代码结构的确切程度。

如果callbackcallbackRender一起位于单独的模块中,则可以使用 rewirecallbackRender替换为间谍。

但是,需要注意的是,rewire也不能替换const变量,因此您的代码必须更改。

最新更新