AngularJS でコントローラーをテストする際に問題が発生しました。次のエラーが発生しました。
enter PhantomJS 1.9.7 (Linux) Controller: HeaderCtrl Should redirect on a new user form FAILED
Error: Injector already created, can not register a module!
at workFn (/path/ui/bower_components/angular-mocks/angular-mocks.js:2038)
Error: [ng:areq] Argument 'HeaderCtrl' is not a function, got undefined
http://errors.angularjs.org/1.3.0-beta.5/ng/areq?p0=HeaderCtrl&p1=not%20a%20function%2C%20got%20undefined
at assertArg (/path/ui/bower_components/angular/angular.js:1443)
at assertArgFn (/path/ui/bower_components/angular/angular.js:1454)
at /path/ui/bower_components/angular/angular.js:7134
at /path/test/ui/unit/core/controllers/header.js:37
at invoke (/path/ui/bower_components/angular/angular.js:3873)
at workFn (/path/ui/bower_components/angular-mocks/angular-mocks.js:2171)
undefined
これが私のテストです:
describe('Controller: HeaderCtrl', function () {
//<--------------------------------------------------------------------------->
//- Define the before/after class/test behaviour
//<--------------------------------------------------------------------------->
// load the controller's module
beforeEach( module('MyApp') );
var HeaderCtrl,
authService,
scope;
// define the mock Auth service
beforeEach( function() {
authService = {
auth: function() {}
};
});
// Initialize the controller and a mock scope
beforeEach( inject(function ($controller, $rootScope) {
scope = $rootScope.$new();
HeaderCtrl = $controller('HeaderCtrl', {
$scope: scope,
auth: authService
});
}));
//<--------------------------------------------------------------------------->
//- Tests
//<--------------------------------------------------------------------------->
describe('On a correct login for a new user', function() {
it('Should redirect on a new user form', function () {
});
});
});
そして、私の HeaderCtrl は次のようになります。
angular.module('MyApp')
.controller('HeaderCtrl', function ($scope, $http, $window, $interval, $location, error, core, auth) {
$scope.user = auth.user;
$scope.login = function () {
auth.auth.query(function (data) {
// doing some stuff
});
};
$scope.logged = false;
});
このコントローラーは、そのような他のモジュールで定義されたいくつかのサービスを使用しています。
var services = angular.module('MyApp.services', ['ngResource']);
services.factory('auth', function ($resource, core) {
var factory = {};
factory.auth = $resource('/an/api/rest/service', {}, {
query: {method: 'GET', params: {}, isArray: false}
});
factory.user = {};
return factory;
});
そして、要求されたアプリ定義:
angular
.module('MyApp', [
'ngCookies',
'ngResource',
'ngSanitize',
'ngRoute',
'MyApp.services'
])
.config(function ($locationProvider) {
$locationProvider.html5Mode(false);
})
.config(function ($routeProvider) {
$routeProvider
.when('/', {
templateUrl: 'views/core/main.html',
controller: 'MainCtrl'
})
.otherwise({
redirectTo: '/'
});
});
私は自分のビューで HeaderCtrl direclty を次のように使用します。
<div ng-controller="HeaderCtrl" ng-include="'views/core/fragments/header.html'"></div>
コントローラーがカルマによってロードされていないようですが、カルマ conf ファイルを確認すると、すべての .js ファイルがロードされています...最初に app.js をロードして、モジュールが作成されていることを確認します。
files: [
'../ui/bower_components/angular/angular.js',
'../ui/bower_components/angular-mocks/angular-mocks.js',
'../ui/bower_components/angular-resource/angular-resource.js',
'../ui/bower_components/angular-cookies/angular-cookies.js',
'../ui/bower_components/angular-sanitize/angular-sanitize.js',
'../ui/bower_components/angular-route/angular-route.js',
'../ui/scripts/app.js',
'../ui/scripts/modules.js',
'../ui/scripts/**/*.js',
'../test/ui/**/*.js'
],
私は何か見落としてますか?私は立ち往生しています:'(
前もって助けてください:)
ヤンニグ