Skip to content

Commit

Permalink
Fix helix-rest memory leak (apache#2960)
Browse files Browse the repository at this point in the history
Fix helix-rest stoppable check memory leak
  • Loading branch information
MarkGaox authored Nov 8, 2024
1 parent 7bfffe1 commit 2b54fbb
Show file tree
Hide file tree
Showing 2 changed files with 27 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -202,6 +202,7 @@ protected HttpResponse post(String url, Map<String, Object> payloads) throws IOE
LOG.warn("Received 302 but no Location header is present, stopping retries.");
break; // Break out if there is no valid redirect location
}
EntityUtils.consumeQuietly(response.getEntity());
} else {
LOG.warn("Received non-200 and non-302 status code: {}, payloads: {}", status, payloads);
return response; // Return response without retry
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,10 +20,12 @@
*/

import java.io.IOException;
import java.time.Duration;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
import java.util.Map;
import java.util.concurrent.TimeUnit;

import com.fasterxml.jackson.databind.JsonNode;
import com.fasterxml.jackson.databind.ObjectMapper;
Expand All @@ -36,6 +38,7 @@
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.conn.ConnectTimeoutException;
import org.apache.http.impl.client.HttpClientBuilder;
import org.apache.http.impl.client.HttpClients;
import org.junit.Assert;
import org.mockito.Mock;
Expand Down Expand Up @@ -169,6 +172,29 @@ public void testPostRequestFormat() throws IOException {
}
}

@Test (description = "Validate if the post request has memory leak or no")
public void testMultiplePost() throws IOException {
// a popular echo server that echos all the inputs
final String echoServer = "https://httpbin.org/redirect-to?url=http://httpbin.org/post";
HttpClientBuilder httpClientBuilder = HttpClients.custom()
.evictExpiredConnections()
.setMaxConnPerRoute(1)
.evictIdleConnections(Duration.ofSeconds(30).toMillis(), TimeUnit.MILLISECONDS);
HttpClient httpClient = httpClientBuilder.build();
CustomRestClientImpl customRestClient = new CustomRestClientImpl(httpClient);
HttpResponse response;

for (int i = 0; i < 5; i++) {
response = customRestClient.post(echoServer, Collections.emptyMap());
if (response.getStatusLine().getStatusCode() == HttpStatus.SC_OK) {
JsonNode json = customRestClient.getJsonObject(response);

Assert.assertEquals(json.get("headers").get("Accept").asText(), "application/json");
Assert.assertEquals(json.get("data").asText(), "{}");
}
}
}

@Test
public void testGetPartitionStoppableCheckWhenTimeout() throws IOException {
MockCustomRestClient customRestClient = new MockCustomRestClient(_httpClient);
Expand Down

0 comments on commit 2b54fbb

Please sign in to comment.