Le test de jasmine échoue avec undefined n'est pas une fonction (en évaluant $ browser. $$ checkUrlChange ())

J'ai un contrôleur suivant:

.controller('ProjectUserAddCtrl', ['$scope', 'ProjectUser', '$q', 'i18nNotifications', function($scope, ProjectUser, $q, i18nNotifications) { var buildUnassignedUsers = function(users, project) { var unassignedUsers = []; angular.forEach(users, function(user) { var match; angular.forEach(project.projectUsers, function(projectUser) { if(match) {return;} if(projectUser.user.id === user.id) { match = true; } }); if(!match) { unassignedUsers.push(user); } }); $scope.unassignedUsers = unassignedUsers; }; $q.all([ $scope.users, $scope.project ]).then(function(result) { buildUnassignedUsers($scope.users, $scope.project); $scope.$watch('project', function(newVal) { buildUnassignedUsers($scope.users, $scope.project); }, true ); }); }]); 

Et un test suivant dans le jasmin:

 describe('ProjectUserAddCtrl', function() { var ctrl; beforeEach(function(){ $scope.users = []; $scope.project = { projectUsers: [] }; ctrl = $controller('ProjectUserAddCtrl', {$scope:$scope, ProjectUser:ProjectUser, $q:$q, i18nNotifications:i18nNotifications}); }); it('should create a new instance', function() { expect(ctrl).toBeDefined(); }); // this test fails! it('should create a list of unassigned users', function() { $scope.$apply(); // need to call apply to resolve promises expect($scope.unassignedUsers).toBeDefined(); }); }); 

'Devrait créer une liste de test des utilisateurs non affectés échoue avec cette erreur:

TypeError: 'undefined' n'est pas une fonction (en évaluant $ browser. $$ checkUrlChange ())

Je n'ai vraiment aucune idée de pourquoi. Toute aide appréciée.

Il semble que cette question se produise lorsque vous avez désagréable entre angular.js et angular-mocks.js Assurez-vous que les deux fichiers sont de la même version.

Ignorez mon commentaire original à la question

J'avais déjà ressenti les mêmes problèmes avec notre projet Rail.

Nous avons amélioré angular.js à 1.2.24, puis notre test de cuillère a commencé à échouer. J'ai examiné les sources angulaires de l'histoire, etc., puis j'ai réalisé que nous avions oublié de mettre à jour les modélisations angulaires (nous utilisions l'ancienne version 1.2.20, donc nous devons exécuter les bundle update rails-assets-angular-mocks Force cette modification). Après avoir appliqué de nouvelles modélisations (ils ont déjà la fonction $$checkUrlChange ), tout a commencé à fonctionner.

Donc, il semble que vous essayez également d'utiliser de vieux objets simulés.