我有一个跟随控制器:
.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())
我真的不知道为什么。任何帮助表示赞赏。
答案 0 :(得分:57)
当你在angular.js和angular-mocks.js之间不匹配时,似乎会发生这个问题。确保这两个文件的版本相同。
请忽略我对问题的原始评论
答案 1 :(得分:4)
我遇到过与rails项目完全相同的问题。
我们将angular.js升级到1.2.24,然后我们的茶匙测试套件开始失败。我查看了angular.js来源/提交故事等,然后意识到,我们忘记更新角度模拟(我们使用旧的1.2.20版本,所以我们需要运行bundle update rails-assets-angular-mocks
来强制进行此更改) 。应用新的模拟后(他们已经有$$checkUrlChange
函数模拟)一切都开始工作了。
所以看起来你也试图使用旧的模拟对象。