我正在尝试使用Jasmine和Chutzpah测试运行器对一些角度代码进行单元测试。 我有一个包含很多依赖项的模块:
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。有任何想法吗 ?感谢。
答案 0 :(得分:0)
我遇到了与模块依赖关系相同的问题并找到了解决方案。依赖关系在单独的js文件中定义,例如ngSanitize。所以将它们添加到测试文件的开头,如下所示:
/// <reference path="../../../../bower_components/angular-sanitize/angular-sanitize.js" />
你只需按照以下方式模拟你的模块:
beforeEach
(function(){
module('app');
});
或更短的版本:
beforeEach(module('app'));
希望这有帮助
答案 1 :(得分:0)
我有同样的问题。在我的测试文件的开头,有下一个顺序的引用:
app.controller.js
错误是因为'app'
中的代码在app.module.js
中声明之前使用了模块app.module.js
。为了解决这个问题,我只是将/// <reference path="../app/app.module.js" />
/// <reference path="../app/app.controller.js" />
/// <reference .........
放在我所有其他的.js引用之前:
$('.date-transform').each(function(){
var initialDate = moment($(this).html(), 'MMMM D, YYYY HH:mm');
if (initialDate.isValid()) {
var offset = moment().utcOffset(); // this is the client UTC offset
var finalDate = initialDate.add(offset, 'minutes').format('MMMM D, YYYY HH:mm');
$(this).html(finalDate);
}
});