Chutzpah - 模块不可用

时间:2016-01-04 14:48:16

标签: angularjs unit-testing jasmine chutzpah

我正在尝试使用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。有任何想法吗 ?感谢。

2 个答案:

答案 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); } });