|
41 | 41 | * Unit tests for {@link AbstractServerHttpRequest}.
|
42 | 42 | *
|
43 | 43 | * @author Rossen Stoyanchev
|
| 44 | + * @author Sam Brannen |
44 | 45 | */
|
45 | 46 | public class ServerHttpRequestTests {
|
46 | 47 |
|
@@ -88,7 +89,6 @@ public void queryParamsWithNoValue() throws Exception {
|
88 | 89 |
|
89 | 90 | @Test
|
90 | 91 | public void mutateRequest() throws Exception {
|
91 |
| - |
92 | 92 | SslInfo sslInfo = mock(SslInfo.class);
|
93 | 93 | ServerHttpRequest request = createHttpRequest("/").mutate().sslInfo(sslInfo).build();
|
94 | 94 | assertSame(sslInfo, request.getSslInfo());
|
@@ -123,6 +123,54 @@ public void mutatePathWithEncodedQueryParams() throws Exception {
|
123 | 123 | assertEquals("name=%E6%89%8E%E6%A0%B9", request.getURI().getRawQuery());
|
124 | 124 | }
|
125 | 125 |
|
| 126 | + @Test |
| 127 | + @SuppressWarnings("deprecation") |
| 128 | + public void mutateHeaderByAddingHeaderValues() throws Exception { |
| 129 | + String headerName = "key"; |
| 130 | + String headerValue1 = "value1"; |
| 131 | + String headerValue2 = "value2"; |
| 132 | + |
| 133 | + ServerHttpRequest request = createHttpRequest("/path"); |
| 134 | + assertNull(request.getHeaders().get(headerName)); |
| 135 | + |
| 136 | + request = request.mutate().header(headerName, headerValue1).build(); |
| 137 | + |
| 138 | + assertNotNull(request.getHeaders().get(headerName)); |
| 139 | + assertEquals(1, request.getHeaders().get(headerName).size()); |
| 140 | + assertEquals(headerValue1, request.getHeaders().get(headerName).get(0)); |
| 141 | + |
| 142 | + request = request.mutate().header(headerName, headerValue2).build(); |
| 143 | + |
| 144 | + assertNotNull(request.getHeaders().get(headerName)); |
| 145 | + assertEquals(2, request.getHeaders().get(headerName).size()); |
| 146 | + assertEquals(headerValue1, request.getHeaders().get(headerName).get(0)); |
| 147 | + assertEquals(headerValue2, request.getHeaders().get(headerName).get(1)); |
| 148 | + } |
| 149 | + |
| 150 | + @Test |
| 151 | + public void mutateHeaderBySettingHeaderValues() throws Exception { |
| 152 | + String headerName = "key"; |
| 153 | + String headerValue1 = "value1"; |
| 154 | + String headerValue2 = "value2"; |
| 155 | + String headerValue3 = "value3"; |
| 156 | + |
| 157 | + ServerHttpRequest request = createHttpRequest("/path"); |
| 158 | + assertNull(request.getHeaders().get(headerName)); |
| 159 | + |
| 160 | + request = request.mutate().header(headerName, headerValue1, headerValue2).build(); |
| 161 | + |
| 162 | + assertNotNull(request.getHeaders().get(headerName)); |
| 163 | + assertEquals(2, request.getHeaders().get(headerName).size()); |
| 164 | + assertEquals(headerValue1, request.getHeaders().get(headerName).get(0)); |
| 165 | + assertEquals(headerValue2, request.getHeaders().get(headerName).get(1)); |
| 166 | + |
| 167 | + request = request.mutate().header(headerName, new String[] { headerValue3 }).build(); |
| 168 | + |
| 169 | + assertNotNull(request.getHeaders().get(headerName)); |
| 170 | + assertEquals(1, request.getHeaders().get(headerName).size()); |
| 171 | + assertEquals(headerValue3, request.getHeaders().get(headerName).get(0)); |
| 172 | + } |
| 173 | + |
126 | 174 | private ServerHttpRequest createHttpRequest(String uriString) throws Exception {
|
127 | 175 | URI uri = URI.create(uriString);
|
128 | 176 | MockHttpServletRequest request = new TestHttpServletRequest(uri);
|
|
0 commit comments