【发布时间】:2017-06-15 20:38:21
【问题描述】:
我有一些看起来像这样的代码,在一个名为 logger.ts 的文件中
(function (logger) {
logger.getLogger = function () {
var log4js = require('log4js');
log4js.configure(__dirname + "/../log4js-config.json");
var logger = log4js.getLogger(require('path').basename(__filename));
return logger;
};
})(module.exports);
现在,这里返回的记录器是一个包含诸如“信息”和“错误”等方法的对象。我想监视这些方法并断言它们是使用某些参数调用的。
我在其他类中使用此代码并想模拟和监视“错误”和“信息”方法。因此,我在测试中写了这个
var loggerStub = require('logger');
sinon.spy(loggerStub.getLogger, 'info');
it("should log the query", function() {
var spyCall = loggerStub.info.getCall(0);
expect(spyCall.args[0]).deep.equal("error: " + somethingVariable);
});
运行它会给我错误:
Attempted to wrap undefined property info as function.
我做错了什么?
【问题讨论】:
标签: node.js mocha.js require sinon chai