Angular/Karma/Jasmine - undefined不是一个对象(评估'commLogger.SetLogLevel')
问题描述:
我试图学习Karma和Jasmine单元测试,但我目前在这里遇到一个错误。我试图研究这个网站的所有答案,但没有提供答案。Angular/Karma/Jasmine - undefined不是一个对象(评估'commLogger.SetLogLevel')
以下是我的单元测试文件。
describe('CommLogger', function() {
var commLogger;
beforeEach(module('FileLoggerManager'));
beforeEach(inject(function (CommLogger) {
commLogger = CommLogger;
}));
describe('SetLogLevel', function() {
it('SetLogLevel Spec', function() {
var logLevel = 0;
commLogger.SetLogLevel(logLevel);
expect(commLogger.SetLogLevel).toHaveBeenCalledWith(logLevel);
});
});
});
这是我想单元测试的js文件。
(function() {
'use strict';
angular
.module('FileLoggerManager')
.service('CommLogger', Body);
function Body(LocalData, $q, $timeout) {
var service = {
writeLog: writeLog,
SetFilePath: SetFilePath,
SetMaxLogSize: SetMaxLogSize,
DeleteLogFiles: DeleteLogFiles
};
var maxloglevel = 2;
function SetLogLevel (logLevel) {
console.log("Comm Logger: Set log level to " + logLevel);
maxloglevel = logLevel;
}
return service;
}
})();
我很乐意为您提供任何帮助。提前致谢!
答
我认为问题在于你的CommLogger
服务没有公开公开SetLogLevel
函数。这里尝试将它添加:
var service = {
...
SetLogLevel: SetLogLevel
};
另外,如果你想使用toHaveBeenCalledWith
你需要刺探功能:
describe('SetLogLevel', function() {
it('SetLogLevel Spec', function() {
spyOn(commLogger, 'SetLogLevel').and.callThrough();
var logLevel = 0;
commLogger.SetLogLevel(logLevel);
expect(commLogger.SetLogLevel).toHaveBeenCalledWith(logLevel);
});
});
查看jasmine spies更多信息。
当'inject'运行时,你有引导错误,所以变量没有被赋值。应该有一个错误,但如果没有,这可能是因为Phantomjs以吞咽错误而闻名。尝试切换到Chrome或将所有内容从“beforeEach”移动到“it”以查看错误。 – estus