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; 
     } 
})(); 

我很乐意为您提供任何帮助。提前致谢!

+0

当'inject'运行时,你有引导错误,所以变量没有被赋值。应该有一个错误,但如果没有,这可能是因为Phantomjs以吞咽错误而闻名。尝试切换到Chrome或将所有内容从“beforeEach”移动到“it”以查看错误。 – estus

我认为问题在于你的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更多信息。