Подтвердить что ты не робот

Тест жасмина с undefined не является функцией (оценка $browser. $$ checkUrlChange())

У меня есть следующий контроллер:

.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())

Я действительно не понимаю, почему. Любая помощь была оценена.

4b9b3361

Ответ 1

Кажется, эта проблема возникает, если у вас есть несоответствие между angular.js и angular -mocks.js Убедитесь, что два файла имеют одну и ту же версию.

Пожалуйста, проигнорируйте мой оригинальный комментарий к вопросу

Ответ 2

У меня возникли те же проблемы с нашим проектом 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.