小编Ego*_*nov的帖子

AngularJS - 单元测试文件上传

如你所知,里面的单元测试它的内置angularjs功能与$ httpBackend模拟XHR请求 - 这是在写单元测试好,乐于助人.

最近,我遇到了在文件上传的情况下嘲笑XHR的需要,并发现了一些问题.

考虑以下代码:

var xhr = new XMLHttpRequest();

xhr.upload.addEventListener("progress", uploadProgress(event), false);
xhr.addEventListener("load", uploadComplete(event), false);
xhr.addEventListener("error", uploadError(event), false);
xhr.addEventListener("abort", uploadAbort(event), false);
xhr.open("POST", 'some url');
xhr.send(someData);
Run Code Online (Sandbox Code Playgroud)

我想做的是通过模拟XHR请求来对这样的代码进行单元测试,但是不可能这样做,因为这里没有使用$ http服务.

我试过这个(它正在工作,可以用$ httpBackend嘲笑):

$http({
    method: 'POST', 
    url: 'some url', 
    data: someData, 
    headers: {'Content-Type': undefined},
    transformRequest: angular.identity})
.then(successCallback, errorCallback);
Run Code Online (Sandbox Code Playgroud)

但在这种情况下,我不知道如何实现'progress'回调和'abort'回调(它们是必不可少的,并且在我现在正在处理的情况下是必需的).

我已经看到最新的Angular支持进程回调承诺的信息(不确定它是否与$ http服务集成),但是中止回调呢?

任何想法或者你之前遇到类似的东西?

testing unit-testing mocking angularjs

6
推荐指数
1
解决办法
3991
查看次数

标签 统计

angularjs ×1

mocking ×1

testing ×1

unit-testing ×1