单元测试Angularjs文件上传控制器方法

时间:2013-12-30 15:52:23

标签: unit-testing angularjs jasmine karma-runner

我正在尝试对负责文件上传的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)

任何人都可以帮助我,我是茉莉和业力单元测试的新手

1 个答案:

答案 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 / $资源。