我正在尝试对负责文件上传的Angularjs中的控制器方法进行单元测试:
$scope.uploadFile = function() {
var fd = new FormData();
for (var i in $scope.files) {
fd.append("uploadedFile", $scope.files[i]);
}
var xhr = new XMLHttpRequest();
xhr.addEventListener("load", $scope.uploadComplete, false);
xhr.addEventListener("error", uploadFailed, false);
xhr.open("POST", "/fileupload");
xhr.send(fd);
}
我试图像下面这样模拟xhr对象:
it("using $window ", inject(function($window) {
$window.XMLHttpRequest= angular.noop;
addEventListenerSpy = jasmine.createSpy("addEventListener");
openSpy = jasmine.createSpy("open");
sendSpy = jasmine.createSpy("send");
xhrObj = {
upload:
{
addEventListener: addEventListenerSpy
},
addEventListener: addEventListenerSpy,
open: openSpy,
send: sendSpy
};
spyOn($window, "XMLHttpRequest").andReturn(xhrObj);
}));
当我运行karma测试配置文件时,我有以下错误:
TypeError:尝试分配给readonly属性。 at workFn(/home/dre/trunk/app/bower_components/angular-mocks/angular-mocks.js:2107)
任何人都可以帮助我,我是茉莉和业力单元测试的新手
答案 0 :(得分:1)
您应该使用Angular依赖注入,这有助于测试。您还应该使用Angular的$ http或$ resource服务来执行XHR请求。
话虽如此,我为你的考试创造了一个小提琴。 您的问题中缺少测试实施,例如控制器创建。 我希望完整的示例能为您提供有关代码中问题的线索。
it("using $window ", function () {
xhrObj = jasmine.createSpyObj('xhrObj',
['addEventListener', 'open', 'send']);
spyOn(window, "XMLHttpRequest").andReturn(xhrObj);
scope.uploadFile()
expect(xhrObj.addEventListener).toHaveBeenCalled();
expect(xhrObj.addEventListener.calls.length).toBe(2);
});
您可以找到完整示例here。
但我建议你改用$ http / $资源。