Ответ 1
Кажется, эта проблема возникает, если у вас есть несоответствие между angular.js и angular -mocks.js Убедитесь, что два файла имеют одну и ту же версию.
Пожалуйста, проигнорируйте мой оригинальный комментарий к вопросу
У меня есть следующий контроллер:
.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
);
});
}]);
И следующий тест в жасмине:
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();
});
});
'должен создать список тестов неназначенных пользователей с этой ошибкой:
TypeError: 'undefined' не является функцией (оценивая $browser. $$ checkUrlChange())
Я действительно не понимаю, почему. Любая помощь была оценена.
Кажется, эта проблема возникает, если у вас есть несоответствие между angular.js и angular -mocks.js Убедитесь, что два файла имеют одну и ту же версию.
Пожалуйста, проигнорируйте мой оригинальный комментарий к вопросу
У меня возникли те же проблемы с нашим проектом rails.
Мы обновили angular.js до 1.2.24, а затем наш чайный чай testuite начал сбой. Я заглянул в angular.js sources/commits story и т.д., А затем понял, что мы забыли обновить angular mocks (мы использовали старую версию 1.2.20, поэтому нам нужно запустить bundle update rails-assets-angular-mocks
, чтобы заставить это изменение). После применения новых mocks (у них уже есть функция $$checkUrlChange
функция mock) все началось.
Итак, похоже, вы также пытаетесь использовать старые объекты mocks.