Ensure withBasicAuth keeps error handler
Fix `TestRestTemplate` so that any custom `ErrorHandler` isn't lost when calling `withBasicAuth`. Fixes gh-7441
This commit is contained in:
parent
3423ca87b4
commit
1452d3cd51
|
@ -916,14 +916,16 @@ public class TestRestTemplate {
|
||||||
*/
|
*/
|
||||||
public TestRestTemplate withBasicAuth(String username, String password) {
|
public TestRestTemplate withBasicAuth(String username, String password) {
|
||||||
RestTemplate restTemplate = new RestTemplate();
|
RestTemplate restTemplate = new RestTemplate();
|
||||||
restTemplate.setErrorHandler(getRestTemplate().getErrorHandler());
|
|
||||||
restTemplate.setMessageConverters(getRestTemplate().getMessageConverters());
|
restTemplate.setMessageConverters(getRestTemplate().getMessageConverters());
|
||||||
restTemplate.setInterceptors(
|
restTemplate.setInterceptors(
|
||||||
removeBasicAuthInterceptorIfPresent(getRestTemplate().getInterceptors()));
|
removeBasicAuthInterceptorIfPresent(getRestTemplate().getInterceptors()));
|
||||||
restTemplate.setRequestFactory(getRestTemplate().getRequestFactory());
|
restTemplate.setRequestFactory(getRestTemplate().getRequestFactory());
|
||||||
restTemplate.setUriTemplateHandler(getRestTemplate().getUriTemplateHandler());
|
restTemplate.setUriTemplateHandler(getRestTemplate().getUriTemplateHandler());
|
||||||
return new TestRestTemplate(restTemplate, username, password,
|
TestRestTemplate testRestTemplate = new TestRestTemplate(restTemplate, username,
|
||||||
this.httpClientOptions);
|
password, this.httpClientOptions);
|
||||||
|
testRestTemplate.getRestTemplate()
|
||||||
|
.setErrorHandler(getRestTemplate().getErrorHandler());
|
||||||
|
return testRestTemplate;
|
||||||
}
|
}
|
||||||
|
|
||||||
private List<ClientHttpRequestInterceptor> removeBasicAuthInterceptorIfPresent(
|
private List<ClientHttpRequestInterceptor> removeBasicAuthInterceptorIfPresent(
|
||||||
|
|
|
@ -34,6 +34,7 @@ import org.springframework.http.client.support.BasicAuthorizationInterceptor;
|
||||||
import org.springframework.test.util.ReflectionTestUtils;
|
import org.springframework.test.util.ReflectionTestUtils;
|
||||||
import org.springframework.util.ReflectionUtils;
|
import org.springframework.util.ReflectionUtils;
|
||||||
import org.springframework.util.ReflectionUtils.MethodCallback;
|
import org.springframework.util.ReflectionUtils.MethodCallback;
|
||||||
|
import org.springframework.web.client.ResponseErrorHandler;
|
||||||
import org.springframework.web.client.RestOperations;
|
import org.springframework.web.client.RestOperations;
|
||||||
import org.springframework.web.client.RestTemplate;
|
import org.springframework.web.client.RestTemplate;
|
||||||
|
|
||||||
|
@ -157,25 +158,32 @@ public class TestRestTemplateTests {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void withBasicAuthReplacesBasicAuthInterceptorWhenAlreadyPresent() {
|
public void withBasicAuthReplacesBasicAuthInterceptorWhenAlreadyPresent() {
|
||||||
TestRestTemplate originalTemplate = new TestRestTemplate("foo", "bar");
|
TestRestTemplate original = new TestRestTemplate("foo", "bar");
|
||||||
TestRestTemplate basicAuthTemplate = originalTemplate.withBasicAuth("user",
|
TestRestTemplate basicAuth = original.withBasicAuth("user", "password");
|
||||||
"password");
|
assertThat(basicAuth.getRestTemplate().getMessageConverters())
|
||||||
assertThat(basicAuthTemplate.getRestTemplate().getMessageConverters())
|
|
||||||
.containsExactlyElementsOf(
|
.containsExactlyElementsOf(
|
||||||
originalTemplate.getRestTemplate().getMessageConverters());
|
original.getRestTemplate().getMessageConverters());
|
||||||
assertThat(basicAuthTemplate.getRestTemplate().getRequestFactory())
|
assertThat(basicAuth.getRestTemplate().getRequestFactory())
|
||||||
.isInstanceOf(InterceptingClientHttpRequestFactory.class);
|
.isInstanceOf(InterceptingClientHttpRequestFactory.class);
|
||||||
assertThat(ReflectionTestUtils.getField(
|
assertThat(ReflectionTestUtils.getField(
|
||||||
basicAuthTemplate.getRestTemplate().getRequestFactory(),
|
basicAuth.getRestTemplate().getRequestFactory(), "requestFactory"))
|
||||||
"requestFactory"))
|
|
||||||
.isInstanceOf(CustomHttpComponentsClientHttpRequestFactory.class);
|
.isInstanceOf(CustomHttpComponentsClientHttpRequestFactory.class);
|
||||||
assertThat(basicAuthTemplate.getRestTemplate().getUriTemplateHandler())
|
assertThat(basicAuth.getRestTemplate().getUriTemplateHandler())
|
||||||
.isSameAs(originalTemplate.getRestTemplate().getUriTemplateHandler());
|
.isSameAs(original.getRestTemplate().getUriTemplateHandler());
|
||||||
assertThat(basicAuthTemplate.getRestTemplate().getInterceptors())
|
assertThat(basicAuth.getRestTemplate().getInterceptors())
|
||||||
.containsExactlyElementsOf(
|
.containsExactlyElementsOf(original.getRestTemplate().getInterceptors());
|
||||||
originalTemplate.getRestTemplate().getInterceptors());
|
assertBasicAuthorizationInterceptorCredentials(basicAuth, "user", "password");
|
||||||
assertBasicAuthorizationInterceptorCredentials(basicAuthTemplate, "user",
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void withBasicAuthDoesNotResetErrorHandler() throws Exception {
|
||||||
|
TestRestTemplate originalTemplate = new TestRestTemplate("foo", "bar");
|
||||||
|
ResponseErrorHandler errorHandler = mock(ResponseErrorHandler.class);
|
||||||
|
originalTemplate.getRestTemplate().setErrorHandler(errorHandler);
|
||||||
|
TestRestTemplate basicAuthTemplate = originalTemplate.withBasicAuth("user",
|
||||||
"password");
|
"password");
|
||||||
|
assertThat(basicAuthTemplate.getRestTemplate().getErrorHandler())
|
||||||
|
.isSameAs(errorHandler);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void assertBasicAuthorizationInterceptorCredentials(
|
private void assertBasicAuthorizationInterceptorCredentials(
|
||||||
|
|
Loading…
Reference in New Issue