我正在尝试使用Jasmine和Chutzpah test runner对一些angular代码进行单元测试。我有一个有很多依赖项的模块:
angular.module('app', ['ngRoute', 'ngSanitize', '7minWorkout', 'WorkoutBuilder', 'mediaPlayer', 'ui.bootstrap', 'LocalStorageModule', 'ngAnimate', 'ngMessages', 'ngResource']);我尝试像这样加载依赖项:
beforeEach
(function(){
angular.mock.module('ngRoute', []);
angular.mock.module('ngSanitize', []);
angular.mock.module('WorkoutBuilder', []);
angular.mock.module('mediaPlayer', []);
angular.mock.module('ui.bootstrap', []);
angular.mock.module('LocalStorageModule', []);
angular.mock.module('ngAnimate', []);
angular.mock.module('ngMessages', []);
angular.mock.module('ngResource', []);
angular.mock.module('7minWorkout', []);
module('app');
}); 当我尝试使用Chutzpah运行单元测试时,我得到以下错误:
**模块'app‘不可用!您要么拼写错误模块名称,要么忘记加载它。如果注册一个模块,请确保将依赖项指定为第二个参数。**
我还尝试像这样指定依赖关系:
beforeEach(function(){
...
module('app', [...... long list of dependencies])
})还是没有结果。我在karma test runner上找到了一些关于这类问题的文章,但没有找到任何关于Chutzpah的文章。有什么想法吗?谢谢。
发布于 2016-04-14 00:08:00
我在模块依赖方面也遇到了同样的问题,并找到了解决方案。依赖关系在单独的js文件中定义,例如ngSanitize。因此,将它们添加到测试文件的开头,如下所示:
/// <reference path="../../../../bower_components/angular-sanitize/angular-sanitize.js" />你只需要像下面这样模拟你的模块:
beforeEach
(function(){
module('app');
}); 或者更短的版本:
beforeEach(module('app')); 希望这能有所帮助
发布于 2016-10-31 23:33:34
我也有同样的问题。在我的测试文件的开头,有以下顺序的引用:
/// <reference path="../app/app.controller.js" /> /// <reference path="../app/app.module.js" /> /// <reference .........
错误是因为app.controller.js中的代码在app.module.js中声明之前使用了模块'app'。为了解决这个问题,我只需将app.module.js放在所有其他.js引用之前:
/// <reference path="../app/app.module.js" /> /// <reference path="../app/app.controller.js" /> /// <reference .........
https://stackoverflow.com/questions/34593716
复制相似问题