Skip to content

Commit 1154c16

Browse files
committed
Finish span in HttpResponseWrapper when closing, if the response was not parsed
1 parent f8d8ce5 commit 1154c16

File tree

1 file changed

+7
-0
lines changed
  • dd-java-agent/instrumentation/openai-java/openai-java-3.0/src/main/java/datadog/trace/instrumentation/openai_java

1 file changed

+7
-0
lines changed

dd-java-agent/instrumentation/openai-java/openai-java-3.0/src/main/java/datadog/trace/instrumentation/openai_java/HttpResponseWrapper.java

Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -7,6 +7,7 @@
77
import datadog.trace.bootstrap.instrumentation.api.AgentSpan;
88
import java.io.InputStream;
99
import java.util.concurrent.CompletableFuture;
10+
import java.util.concurrent.atomic.AtomicBoolean;
1011
import java.util.function.BiConsumer;
1112
import org.jetbrains.annotations.NotNull;
1213
import org.slf4j.Logger;
@@ -43,6 +44,7 @@ public static <T> CompletableFuture<HttpResponseFor<T>> wrapFuture(
4344
private final HttpResponseFor<T> delegate;
4445
private final AgentSpan span;
4546
private final BiConsumer<AgentSpan, T> decorate;
47+
private final AtomicBoolean finished = new AtomicBoolean(false);
4648

4749
private HttpResponseWrapper(
4850
HttpResponseFor<T> delegate, AgentSpan span, BiConsumer<AgentSpan, T> decorate) {
@@ -58,6 +60,7 @@ public T parse() {
5860
parsed = delegate.parse();
5961
} catch (Throwable err) {
6062
DECORATE.finishSpan(span, err);
63+
finished.set(true);
6164
throw err;
6265
}
6366
try {
@@ -66,6 +69,7 @@ public T parse() {
6669
log.debug("Span decorator failed", t);
6770
} finally {
6871
DECORATE.finishSpan(span, null);
72+
finished.set(true);
6973
}
7074
return parsed;
7175
}
@@ -89,6 +93,9 @@ public InputStream body() {
8993

9094
@Override
9195
public void close() {
96+
if (finished.compareAndSet(false, true)) {
97+
DECORATE.finishSpan(span, null);
98+
}
9299
delegate.close();
93100
}
94101
}

0 commit comments

Comments
 (0)