Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
爱吃血肠
spring-framework
提交
9243a147
S
spring-framework
项目概览
爱吃血肠
/
spring-framework
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
S
spring-framework
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
9243a147
编写于
1月 31, 2017
作者:
J
Juergen Hoeller
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Test for correct handling of multiple header values
Issue: SPR-15166
上级
23aac2de
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
27 addition
and
28 deletion
+27
-28
spring-web/src/test/java/org/springframework/http/client/InterceptingClientHttpRequestFactoryTests.java
...ttp/client/InterceptingClientHttpRequestFactoryTests.java
+27
-28
未找到文件。
spring-web/src/test/java/org/springframework/http/client/InterceptingClientHttpRequestFactoryTests.java
浏览文件 @
9243a147
/*
* Copyright 2002-201
6
the original author or authors.
* Copyright 2002-201
7
the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
...
...
@@ -26,7 +26,6 @@ import java.util.Arrays;
import
java.util.Collections
;
import
java.util.List
;
import
org.junit.Before
;
import
org.junit.Test
;
import
org.springframework.http.HttpHeaders
;
...
...
@@ -37,25 +36,20 @@ import org.springframework.http.client.support.HttpRequestWrapper;
import
static
org
.
junit
.
Assert
.*;
/** @author Arjen Poutsma */
/**
* @author Arjen Poutsma
* @author Juergen Hoeller
*/
public
class
InterceptingClientHttpRequestFactoryTests
{
private
InterceptingClientHttpRequestFactory
requestFactory
;
private
RequestFactoryMock
requestFactoryMock
;
private
RequestFactoryMock
requestFactoryMock
=
new
RequestFactoryMock
();
private
RequestMock
requestMock
;
private
RequestMock
requestMock
=
new
RequestMock
()
;
private
ResponseMock
responseMock
;
private
ResponseMock
responseMock
=
new
ResponseMock
()
;
@Before
public
void
setUp
()
throws
Exception
{
requestFactoryMock
=
new
RequestFactoryMock
();
requestMock
=
new
RequestMock
();
responseMock
=
new
ResponseMock
();
private
InterceptingClientHttpRequestFactory
requestFactory
;
}
@Test
public
void
basic
()
throws
Exception
{
...
...
@@ -101,29 +95,29 @@ public class InterceptingClientHttpRequestFactoryTests {
public
void
changeHeaders
()
throws
Exception
{
final
String
headerName
=
"Foo"
;
final
String
headerValue
=
"Bar"
;
final
String
otherValue
=
"Baz"
;
ClientHttpRequestInterceptor
interceptor
=
new
ClientHttpRequestInterceptor
()
{
@Override
public
ClientHttpResponse
intercept
(
HttpRequest
request
,
byte
[]
body
,
ClientHttpRequestExecution
execution
)
throws
IOException
{
return
execution
.
execute
(
new
HttpRequestWrapper
(
request
)
{
@Override
public
HttpHeaders
getHeaders
()
{
HttpHeaders
headers
=
new
HttpHeaders
();
headers
.
set
(
headerName
,
headerValue
);
return
headers
;
}
},
body
);
HttpRequestWrapper
wrapper
=
new
HttpRequestWrapper
(
request
);
wrapper
.
getHeaders
().
add
(
headerName
,
otherValue
);
return
execution
.
execute
(
wrapper
,
body
);
}
};
requestMock
=
new
RequestMock
()
{
@Override
public
ClientHttpResponse
execute
()
throws
IOException
{
assertEquals
(
headerValue
,
getHeaders
().
getFirst
(
headerName
));
List
<
String
>
headerValues
=
getHeaders
().
get
(
headerName
);
assertEquals
(
2
,
headerValues
.
size
());
assertEquals
(
headerValue
,
headerValues
.
get
(
0
));
assertEquals
(
otherValue
,
headerValues
.
get
(
1
));
return
super
.
execute
();
}
};
requestMock
.
getHeaders
().
add
(
headerName
,
headerValue
);
requestFactory
=
new
InterceptingClientHttpRequestFactory
(
requestFactoryMock
,
Collections
.
singletonList
(
interceptor
));
...
...
@@ -135,11 +129,11 @@ public class InterceptingClientHttpRequestFactoryTests {
@Test
public
void
changeURI
()
throws
Exception
{
final
URI
changedUri
=
new
URI
(
"http://example.com/2"
);
ClientHttpRequestInterceptor
interceptor
=
new
ClientHttpRequestInterceptor
()
{
@Override
public
ClientHttpResponse
intercept
(
HttpRequest
request
,
byte
[]
body
,
ClientHttpRequestExecution
execution
)
throws
IOException
{
return
execution
.
execute
(
new
HttpRequestWrapper
(
request
)
{
@Override
public
URI
getURI
()
{
...
...
@@ -168,11 +162,11 @@ public class InterceptingClientHttpRequestFactoryTests {
@Test
public
void
changeMethod
()
throws
Exception
{
final
HttpMethod
changedMethod
=
HttpMethod
.
POST
;
ClientHttpRequestInterceptor
interceptor
=
new
ClientHttpRequestInterceptor
()
{
@Override
public
ClientHttpResponse
intercept
(
HttpRequest
request
,
byte
[]
body
,
ClientHttpRequestExecution
execution
)
throws
IOException
{
return
execution
.
execute
(
new
HttpRequestWrapper
(
request
)
{
@Override
public
HttpMethod
getMethod
()
{
...
...
@@ -201,11 +195,11 @@ public class InterceptingClientHttpRequestFactoryTests {
@Test
public
void
changeBody
()
throws
Exception
{
final
byte
[]
changedBody
=
"Foo"
.
getBytes
();
ClientHttpRequestInterceptor
interceptor
=
new
ClientHttpRequestInterceptor
()
{
@Override
public
ClientHttpResponse
intercept
(
HttpRequest
request
,
byte
[]
body
,
ClientHttpRequestExecution
execution
)
throws
IOException
{
return
execution
.
execute
(
request
,
changedBody
);
}
};
...
...
@@ -218,6 +212,7 @@ public class InterceptingClientHttpRequestFactoryTests {
assertTrue
(
Arrays
.
equals
(
changedBody
,
requestMock
.
body
.
toByteArray
()));
}
private
static
class
NoOpInterceptor
implements
ClientHttpRequestInterceptor
{
private
boolean
invoked
=
false
;
...
...
@@ -230,6 +225,7 @@ public class InterceptingClientHttpRequestFactoryTests {
}
}
private
class
RequestFactoryMock
implements
ClientHttpRequestFactory
{
@Override
...
...
@@ -241,6 +237,7 @@ public class InterceptingClientHttpRequestFactoryTests {
}
private
class
RequestMock
implements
ClientHttpRequest
{
private
URI
uri
;
...
...
@@ -291,6 +288,7 @@ public class InterceptingClientHttpRequestFactoryTests {
}
}
private
static
class
ResponseMock
implements
ClientHttpResponse
{
private
HttpStatus
statusCode
=
HttpStatus
.
OK
;
...
...
@@ -328,4 +326,5 @@ public class InterceptingClientHttpRequestFactoryTests {
public
void
close
()
{
}
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录