Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xjbieke
axios
提交
7a16f728
A
axios
项目概览
xjbieke
/
axios
与 Fork 源项目一致
从无法访问的项目Fork
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
A
axios
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
7a16f728
编写于
1月 22, 2016
作者:
M
Matt Zabriskie
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Improving logic for handling timeout in node
closes #124
上级
d31ebc4c
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
47 addition
and
3 deletion
+47
-3
lib/adapters/http.js
lib/adapters/http.js
+19
-3
test/unit/adapters/http.js
test/unit/adapters/http.js
+28
-0
未找到文件。
lib/adapters/http.js
浏览文件 @
7a16f728
...
...
@@ -13,6 +13,8 @@ var Buffer = require('buffer').Buffer;
module
.
exports
=
function
httpAdapter
(
resolve
,
reject
,
config
)
{
var
data
=
config
.
data
;
var
headers
=
config
.
headers
;
var
timer
;
var
aborted
=
false
;
// Set User-Agent (required by some servers)
// Only set header if it hasn't been set in config
...
...
@@ -57,6 +59,12 @@ module.exports = function httpAdapter(resolve, reject, config) {
// Create the request
var
transport
=
parsed
.
protocol
===
'
https:
'
?
https
:
http
;
var
req
=
transport
.
request
(
options
,
function
handleResponse
(
res
)
{
if
(
aborted
)
return
;
// Response has been received so kill timer that handles request timeout
clearTimeout
(
timer
);
timer
=
null
;
// uncompress the response body transparently if required
var
stream
=
res
;
switch
(
res
.
headers
[
'
content-encoding
'
])
{
...
...
@@ -103,13 +111,21 @@ module.exports = function httpAdapter(resolve, reject, config) {
// Handle errors
req
.
on
(
'
error
'
,
function
handleRequestError
(
err
)
{
if
(
aborted
)
return
;
reject
(
err
);
});
// Handle request timeout
req
.
setTimeout
(
config
.
timeout
,
function
handleRequestTimeout
()
{
req
.
abort
();
});
if
(
config
.
timeout
&&
!
timer
)
{
timer
=
setTimeout
(
function
handleRequestTimeout
()
{
var
err
=
new
Error
(
'
timeout of
'
+
config
.
timeout
+
'
ms exceeded
'
);
err
.
timeout
=
config
.
timeout
;
err
.
code
=
'
ECONNABORTED
'
;
req
.
abort
();
reject
(
err
);
aborted
=
true
;
},
config
.
timeout
);
}
// Send the request
req
.
end
(
data
);
...
...
test/unit/adapters/http.js
浏览文件 @
7a16f728
...
...
@@ -11,6 +11,34 @@ module.exports = {
callback
();
},
testTimeout
:
function
(
test
)
{
server
=
http
.
createServer
(
function
(
req
,
res
)
{
setTimeout
(
function
()
{
res
.
end
();
},
1000
);
}).
listen
(
4444
,
function
()
{
var
success
=
false
,
failure
=
false
;
var
error
;
axios
.
get
(
'
http://localhost:4444/
'
,
{
timeout
:
250
}).
then
(
function
(
res
)
{
success
=
true
;
}).
catch
(
function
(
res
)
{
error
=
res
;
failure
=
true
;
});
setTimeout
(
function
()
{
test
.
equal
(
success
,
false
,
'
request should not succeed
'
);
test
.
equal
(
failure
,
true
,
'
request should fail
'
);
test
.
equal
(
error
.
code
,
'
ECONNABORTED
'
);
test
.
equal
(
error
.
message
,
'
timeout of 250ms exceeded
'
);
test
.
done
();
},
300
);
});
},
testJSON
:
function
(
test
)
{
var
data
=
{
firstName
:
'
Fred
'
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录