2016-08-03 132 views
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

回答

0

我不包括在我的应用程序声明require('angular-mocks/ngMock')。有时候,这是小事。

+0

嘿伙计,你能接受它作为答案,以便这个问题将被关闭 – dreamweiver

相关问题