我正在构建一个应用程序,我需要在其中测试快速回调解析中的一些回调行为。
实际上,它看起来像:
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
)都将调用原始函数,而不是间谍。
解决方案取决于代码结构的确切程度。
如果callback
和callbackRender
一起位于单独的模块中,则可以使用 rewire
将callbackRender
替换为间谍。
但是,需要注意的是,rewire
也不能替换const
变量,因此您的代码必须更改。