Raise RestClientException for unknown status codes

HttpStatus cannot be created with an unknown status code. If a server
returns a status code that's not in the HttpStatus enum values, an
IllegalArgumentException is raised. Rather than allowing it to
propagate as such, this change ensures the actual exception raised is
a RestClientException.

Issue: SPR-9406
This commit is contained in:
Rossen Stoyanchev 2012-06-12 14:54:16 -04:00
parent 0e3a1d8176
commit ab4952a959
3 changed files with 26 additions and 3 deletions

View File

@ -45,7 +45,18 @@ public class DefaultResponseErrorHandler implements ResponseErrorHandler {
* Delegates to {@link #hasError(HttpStatus)} with the response status code. * Delegates to {@link #hasError(HttpStatus)} with the response status code.
*/ */
public boolean hasError(ClientHttpResponse response) throws IOException { public boolean hasError(ClientHttpResponse response) throws IOException {
return hasError(response.getStatusCode()); return hasError(getStatusCode(response));
}
private HttpStatus getStatusCode(ClientHttpResponse response) throws IOException {
HttpStatus statusCode;
try {
statusCode = response.getStatusCode();
}
catch (IllegalArgumentException ex) {
throw new RestClientException("Unknown status code [" + response.getRawStatusCode() + "]");
}
return statusCode;
} }
/** /**
@ -69,7 +80,7 @@ public class DefaultResponseErrorHandler implements ResponseErrorHandler {
* and a {@link RestClientException} in other cases. * and a {@link RestClientException} in other cases.
*/ */
public void handleError(ClientHttpResponse response) throws IOException { public void handleError(ClientHttpResponse response) throws IOException {
HttpStatus statusCode = response.getStatusCode(); HttpStatus statusCode = getStatusCode(response);
HttpHeaders headers = response.getHeaders(); HttpHeaders headers = response.getHeaders();
MediaType contentType = headers.getContentType(); MediaType contentType = headers.getContentType();
Charset charset = contentType != null ? contentType.getCharSet() : null; Charset charset = contentType != null ? contentType.getCharSet() : null;

View File

@ -124,4 +124,16 @@ public class DefaultResponseErrorHandlerTests {
verify(response); verify(response);
} }
// SPR-9406
@Test(expected=RestClientException.class)
public void unknownStatusCode() throws Exception {
expect(response.getStatusCode()).andThrow(new IllegalArgumentException("No matching constant for 999"));
expect(response.getRawStatusCode()).andReturn(999);
replay(response);
handler.handleError(response);
}
} }

View File

@ -7,7 +7,7 @@ Changes in version 3.2 M2
------------------------- -------------------------
* spring-test module now depends on junit:junit-dep * spring-test module now depends on junit:junit-dep
* raise RestClientException instead of IllegalArgumentException for unknown status codes
Changes in version 3.2 M1 (2012-05-28) Changes in version 3.2 M1 (2012-05-28)
-------------------------------------- --------------------------------------