0
我在单元测试中访问我的服务和过滤器时遇到了问题(我还没有尝试过指令)。我之前编写过单元测试,但由于我已经转移到了我们的构建配置中,因此无法访问我们的新服务来编写单元测试。我不断得到TypeError: null is not an object (evaluating 'currentSpec.$modules') in...
。我做了一些阅读,看起来它可能与我正在使用的节点包有关。我想知道更大的社区是否可以确保这些配置看起来正确。我缩小了下面的文件。与Jasmine,Karma和ng-Mock的角度单元测试服务
使用当前的配置,这是错误的。
的package.json
"devDependencies": {
"angular": "1.5.7",
"angular-mocks": "1.5.7",
"jasmine": "2.4.1",
"jasmine-core": "2.4.1",
"karma-browserify": "5.1.0",
"karma-chrome-launcher": "1.0.1",
"karma-jasmine": "1.0.2",
"karma-nyan-reporter": "0.2.4",
"karma-phantomjs2-launcher": "0.5.0",
"phantomjs2": "2.2.0"
}
karma.conf.js
module.exports = function(config) {
config.set({
basePath: '',
frameworks: ['browserify', 'jasmine'],
files: [
'app/main.js',
'app/modules/**/*.spec.js',
'app/shared/**/**/*.spec.js'
],
preprocessors: {
'app/main.js': ['browserify'],
'app/modules/index.js': ['browserify'],
'app/shared/index.js': ['browserify'],
'app/modules/**/*.spec.js': ['browserify'],
'app/shared/**/**/*.spec.js': ['browserify']
},
})
}
service.spec.js
describe('Unit: Services', function() {
require('angular-mocks/ngMock');
var APIHelper;
beforeEach(function() {
angular.mock.module('app.common.services');
});
beforeEach(inject(function(apiHelperService) {
APIHelper = apiHelperService; //injection is what's breaking
}));
it('should exist', function() {
expect(APIHelper).toBeDefined();
});
});
钍e服务和规格正在以正确的顺序加载。该服务没有依赖关系。我假设当我需要注入服务依赖关系时,我会得到相同的错误,但如果我能够注入注入,我可以根据需要注入适当的服务。
// This worked in a controller
angular.mock.inject(function GetDependencies(service) {
service = service;
});
预先感谢您花时间浏览本文并回答问题。
-W
嘿伙计,你能接受它作为答案,以便这个问题将被关闭 – dreamweiver