我正在使用ngMock在Angular中进行单元测试。我现在有了一个browserify \w Angular设置。我有一些奇怪的行为。当我只是用require('angular-mocks');加载angular-mock时,我的测试和应用程序就正常工作了。但如果我随后将其作为依赖项加载到我的Angular应用程序模块中,它将不再加载我的Angular应用程序,但我的karma测试仍然有效:
(function () {
'use strict';
require('angular');
require('angular-route');
require('angular-mocks');
require('./home');
angular.module('greenboxUi', [
'ngRoute',
//'ngMock',
'greenboxUi.home'
]);
}());如果我取消对ngMock的注释,我的应用程序将不再加载
我的browserify-shim:
'angular-mocks': {
path: './app/bower_components/angular-mocks/angular-mocks.js',
exports: 'angular.mock',
depends: {
angular: 'angular'
}
}我的测试:
beforeEach(function(){
module('greenboxUi.home');
inject(function($controller){
controller = $controller('HomeCtrl');
});
});
it('test test', function() {
expect(controller.hello).toBe('Hello world');
});我的应用程序在注释“ngMock”时确实可以工作,但我只是觉得它有点奇怪,因为Angular文档确实会用angular.module('app', ['ngMock'])加载它。是因为browserify以某种方式包装了模块吗?
亲切的问候,尼尔斯
发布于 2015-08-31 17:50:20
事实上,ngMock不应该添加到"production“项目的依赖项中。
有关更多信息,请参阅此github问题:https://github.com/angular/angular.js/issues/12137
https://stackoverflow.com/questions/29316012
复制相似问题