提交 21fad8e2 编写于 作者: J Juergen Hoeller

SimpleClientHttpResponse catches any Exception on close

Issue: SPR-16773
上级 ad0d79a9
/*
* Copyright 2002-2017 the original author or authors.
* Copyright 2002-2018 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.
......@@ -96,7 +96,7 @@ final class SimpleClientHttpResponse extends AbstractClientHttpResponse {
StreamUtils.drain(this.responseStream);
this.responseStream.close();
}
catch (IOException ex) {
catch (Exception ex) {
// ignore
}
}
......
/*
* Copyright 2002-2017 the original author or authors.
* Copyright 2002-2018 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.
......@@ -22,7 +22,6 @@ import java.io.InputStream;
import java.net.HttpURLConnection;
import java.nio.charset.StandardCharsets;
import org.junit.Before;
import org.junit.Test;
import org.springframework.util.StreamUtils;
......@@ -30,23 +29,18 @@ import org.springframework.util.StreamUtils;
import static org.hamcrest.MatcherAssert.assertThat;
import static org.hamcrest.Matchers.*;
import static org.junit.Assert.*;
import static org.mockito.BDDMockito.any;
import static org.mockito.BDDMockito.*;
/**
* @author Brian Clozel
* @author Juergen Hoeller
*/
public class SimpleClientHttpResponseTests {
private SimpleClientHttpResponse response;
private final HttpURLConnection connection = mock(HttpURLConnection.class);
private HttpURLConnection connection;
@Before
public void setup() throws Exception {
this.connection = mock(HttpURLConnection.class);
this.response = new SimpleClientHttpResponse(this.connection);
}
private final SimpleClientHttpResponse response = new SimpleClientHttpResponse(this.connection);
@Test // SPR-14040
......@@ -98,8 +92,22 @@ public class SimpleClientHttpResponseTests {
verify(this.connection, never()).disconnect();
}
@Test // SPR-16773
public void shouldNotDrainWhenErrorStreamClosed() throws Exception {
InputStream is = mock(InputStream.class);
given(this.connection.getErrorStream()).willReturn(is);
doNothing().when(is).close();
given(is.read(any())).willThrow(new NullPointerException("from HttpURLConnection#ErrorStream"));
InputStream responseStream = this.response.getBody();
responseStream.close();
this.response.close();
verify(is).close();
}
class TestByteArrayInputStream extends ByteArrayInputStream {
private static class TestByteArrayInputStream extends ByteArrayInputStream {
private boolean closed;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册