Skip to content

Commit

Permalink
Don't record start time when Reactive REST Client returns a Multi
Browse files Browse the repository at this point in the history
Fixes: #23829
  • Loading branch information
geoand committed Mar 30, 2022
1 parent c6c2788 commit 57cfcd7
Showing 1 changed file with 7 additions and 2 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@

import io.netty.handler.codec.http.LastHttpContent;
import io.netty.handler.codec.http.multipart.InterfaceHttpData;
import io.smallrye.mutiny.Multi;
import io.smallrye.mutiny.Uni;
import io.smallrye.stork.Stork;
import io.smallrye.stork.api.ServiceInstance;
Expand Down Expand Up @@ -408,15 +409,15 @@ public Uni<HttpClientRequest> createRequest(RestClientRequestContext state) {
try {
serviceInstance = Stork.getInstance()
.getService(serviceName)
.selectInstanceAndRecordStart(true);
.selectInstanceAndRecordStart(shouldMeasureTime(state));
} catch (Throwable e) {
log.error("Error selecting service instance for serviceName: " + serviceName, e);
return Uni.createFrom().failure(e);
}
requestOptions = serviceInstance.onItem().transform(new Function<>() {
@Override
public RequestOptions apply(ServiceInstance serviceInstance) {
if (serviceInstance.gatherStatistics()) {
if (serviceInstance.gatherStatistics() && shouldMeasureTime(state)) {
state.setCallStatsCollector(serviceInstance);
}
return new RequestOptions()
Expand Down Expand Up @@ -457,6 +458,10 @@ public Uni<? extends HttpClientRequest> apply(RequestOptions options) {
});
}

private boolean shouldMeasureTime(RestClientRequestContext state) {
return !Multi.class.equals(state.getResponseType().getRawType());
}

private int getPort(boolean isHttps, int specifiedPort) {
return specifiedPort != -1 ? specifiedPort : defaultPort(isHttps);
}
Expand Down

0 comments on commit 57cfcd7

Please sign in to comment.