【发布时间】:2016-03-08 02:29:35
【问题描述】:
我不明白为什么会出现以下错误:
Chrome 43.0.2357 (Windows 7 0.0.0) 请求控制器测试应该 从 xhr 请求的结果中填充属性失败 TypeError:无法读取未定义的属性“0” 在 getLastStatus (C:/Users/aazor102115/Desktop/Dev/Balrog/Front/Balrog-UI/app/tools.js:68:43) 在 C:/Users/aazor102115/Desktop/Dev/Balrog/Front/Balrog-UI/app/requests/requests.js:238:42 在 processQueue (C:/Users/aazor102115/Desktop/Dev/Balrog/Front/Balrog-UI/bower_components/angular/angular.js:14792:28) 在 C:/Users/aazor102115/Desktop/Dev/Balrog/Front/Balrog-UI/bower_components/angular/angular.js:14808:27 在 Scope.$eval (C:/Users/aazor102115/Desktop/Dev/Balrog/Front/Balrog-UI/bower_components/angular/angular.js:16052:28) 在 Scope.$digest (C:/Users/aazor102115/Desktop/Dev/Balrog/Front/Balrog-UI/bower_components/angular/angular.js:15870:31) 在 Scope.$apply (C:/Users/aazor102115/Desktop/Dev/Balrog/Front/Balrog-UI/bower_components/angular/angular.js:16160:24) 完成(C:/Users/aazor102115/Desktop/Dev/Balrog/Front/Balrog-UI/bower_components/angular/angular.js:10589:47) 在handleResponse (C:/Users/aazor102115/Desktop/Dev/Balrog/Front/Balrog-UI/bower_components/angular-mocks/angular-mocks.js:1194:9) 在 Function.$httpBackend.flush (C:/Users/aazor102115/Desktop/Dev/Balrog/Front/Balrog-UI/bower_components/angular-mocks/angular-mocks.js:1553:26)
此错误仅显示在业力日志上。
但它不应该因为循环条件而未定义。
在 tools.js 文件中:
function getLastStatus(statuses) {
var lastStatusDate = Date.parse(statuses[0].date); // this is the line pointed in the error
var lastIndex = 0;
for (var i = 0; statuses[i]; i++) {
var currentStatusDate = Date.parse(statuses[i].date);
if (currentStatusDate > lastStatusDate) {
lastStatusDate = currentStatusDate;
lastIndex = i;
}
}
return statuses[lastIndex];
}
在 requests.js 文件中:
Requests.query().$promise.then(function(result) {
controllerScope.requestsList = [];
for (var i = 0; result[i]; i++) {
var currentRequest = {
id: result[i]["id"],
projectTitle: result[i]["project"].title,
status: getLastStatus(result[i]["statuses"]).status, // this is the line pointed in the error
description: result[i]["description"],
regions: regionsIdToName(controllerScope.regionsList, result[i]["project"].regions),
requestDate: moment(result[i]["request_date"]).format("MM-DD-YYYY"),
developers: result[i]["developers"],
statusDate: moment(getLastStatus(result[i]["statuses"]).date).format("MM-DD-YYYY")
};
controllerScope.requestsList.push(currentRequest);
}
});
编辑:在getLastStatus(statuses) 函数的第一行添加console.log(statuses); 时:
一个对象数组显示在浏览器控制台上,就像它应该的那样。
但在 Karma 控制台上显示 undefined。所以我不明白是什么原因造成的。
【问题讨论】:
标签: javascript angularjs unit-testing karma-jasmine