Don't use null charset in RequestLogger (#22197)

If the response comes back with a content type with a `null`
charset we were blindly using it, causing `NullPointerException`s.

Closes #22190
This commit is contained in:
Nik Everett 2016-12-15 11:19:51 -05:00 committed by GitHub
parent b6cbcc49ba
commit 2aa89820f3
2 changed files with 18 additions and 5 deletions

View File

@ -152,7 +152,7 @@ final class RequestLogger {
httpResponse.setEntity(entity); httpResponse.setEntity(entity);
ContentType contentType = ContentType.get(entity); ContentType contentType = ContentType.get(entity);
Charset charset = StandardCharsets.UTF_8; Charset charset = StandardCharsets.UTF_8;
if (contentType != null) { if (contentType != null && contentType.getCharset() != null) {
charset = contentType.getCharset(); charset = contentType.getCharset();
} }
try (BufferedReader reader = new BufferedReader(new InputStreamReader(entity.getContent(), charset))) { try (BufferedReader reader = new BufferedReader(new InputStreamReader(entity.getContent(), charset))) {

View File

@ -44,6 +44,7 @@ import java.io.ByteArrayInputStream;
import java.io.IOException; import java.io.IOException;
import java.net.URI; import java.net.URI;
import java.net.URISyntaxException; import java.net.URISyntaxException;
import java.nio.charset.Charset;
import java.nio.charset.StandardCharsets; import java.nio.charset.StandardCharsets;
import static org.hamcrest.CoreMatchers.equalTo; import static org.hamcrest.CoreMatchers.equalTo;
@ -51,7 +52,6 @@ import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertThat; import static org.junit.Assert.assertThat;
public class RequestLoggerTests extends RestClientTestCase { public class RequestLoggerTests extends RestClientTestCase {
public void testTraceRequest() throws IOException, URISyntaxException { public void testTraceRequest() throws IOException, URISyntaxException {
HttpHost host = new HttpHost("localhost", 9200, randomBoolean() ? "http" : "https"); HttpHost host = new HttpHost("localhost", 9200, randomBoolean() ? "http" : "https");
String expectedEndpoint = "/index/type/_api"; String expectedEndpoint = "/index/type/_api";
@ -69,7 +69,7 @@ public class RequestLoggerTests extends RestClientTestCase {
expected += " -d '" + requestBody + "'"; expected += " -d '" + requestBody + "'";
HttpEntityEnclosingRequest enclosingRequest = (HttpEntityEnclosingRequest) request; HttpEntityEnclosingRequest enclosingRequest = (HttpEntityEnclosingRequest) request;
HttpEntity entity; HttpEntity entity;
switch(randomIntBetween(0, 3)) { switch(randomIntBetween(0, 4)) {
case 0: case 0:
entity = new StringEntity(requestBody, StandardCharsets.UTF_8); entity = new StringEntity(requestBody, StandardCharsets.UTF_8);
break; break;
@ -82,6 +82,10 @@ public class RequestLoggerTests extends RestClientTestCase {
case 3: case 3:
entity = new NByteArrayEntity(requestBody.getBytes(StandardCharsets.UTF_8)); entity = new NByteArrayEntity(requestBody.getBytes(StandardCharsets.UTF_8));
break; break;
case 4:
// Evil entity without a charset
entity = new StringEntity(requestBody, (Charset) null);
break;
default: default:
throw new UnsupportedOperationException(); throw new UnsupportedOperationException();
} }
@ -116,11 +120,20 @@ public class RequestLoggerTests extends RestClientTestCase {
expected += "\n# \"field\": \"value\""; expected += "\n# \"field\": \"value\"";
expected += "\n# }"; expected += "\n# }";
HttpEntity entity; HttpEntity entity;
if (getRandom().nextBoolean()) { switch(randomIntBetween(0, 2)) {
case 0:
entity = new StringEntity(responseBody, StandardCharsets.UTF_8); entity = new StringEntity(responseBody, StandardCharsets.UTF_8);
} else { break;
case 1:
//test a non repeatable entity //test a non repeatable entity
entity = new InputStreamEntity(new ByteArrayInputStream(responseBody.getBytes(StandardCharsets.UTF_8))); entity = new InputStreamEntity(new ByteArrayInputStream(responseBody.getBytes(StandardCharsets.UTF_8)));
break;
case 2:
// Evil entity without a charset
entity = new StringEntity(responseBody, (Charset) null);
break;
default:
throw new UnsupportedOperationException();
} }
httpResponse.setEntity(entity); httpResponse.setEntity(entity);
} }