【问题标题】:jasmine test fails with undefined is not a function(evaluating $browser.$$checkUrlChange())茉莉花测试失败,未定义不是函数(评估 $browser.$$checkUrlChange())
【发布时间】:2014-09-11 10:31:42
【问题描述】:

我有以下控制器:

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

});

'should create a list of unassigned users' 测试失败并出现此错误:

TypeError: 'undefined' is not a function(评估 $browser.$$checkUrlChange())

我真的不知道为什么。任何帮助表示赞赏。

【问题讨论】:

  • 我也遇到了同样的问题。我认为这是 1.2.24 的一个 bug,降级到 1.2.23 解决了。
  • 谢谢,我降级到 1.2.23 并且可以正常工作
  • @Buzzy 你应该把它作为答案......

标签: javascript angularjs jasmine karma-jasmine


【解决方案1】:

当您在 angular.js 和 angular-mocks.js 之间存在不匹配时,似乎会发生此问题确保这两个文件的版本相同。

请忽略我对该问题的原始评论

【讨论】:

  • 我只想说这对我帮助很大。非常感谢。
  • 你也帮了我,tks ^^
  • 我仍然收到此错误,版本设置为相同的 1.3.14
  • 也为我工作。谢谢
【解决方案2】:

我在 Rails 项目中遇到了完全相同的问题。

我们将 angular.js 升级到 1.2.24,然后我们的茶匙测试套件开始失败。我查看了 angular.js 源/提交故事等,然后意识到我们忘记更新 Angular 模拟(我们使用的是旧的 1.2.20 版本,所以我们需要运行 bundle update rails-assets-angular-mocks 来强制进行此更改)。应用新的模拟后(他们已经有 $$checkUrlChange 函数模拟)一切都开始工作了。

所以看起来您也尝试使用旧的模拟对象。

【讨论】:

    猜你喜欢
    • 2014-11-13
    • 2015-12-13
    • 1970-01-01
    • 1970-01-01
    • 2016-10-13
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多