From 100e964310b56b1efc32459ac83d7b6a3c77be65 Mon Sep 17 00:00:00 2001 From: Noemi <45180344+unflxw@users.noreply.github.com> Date: Thu, 4 Jul 2024 16:13:26 +0200 Subject: [PATCH] Do not pass timestamp on OpenTelemetry span close This reverts commit 0d60a9bc05a4dd792ea69485b30219d1dfef0655 (#1064) This did not fix the issue for the customer that I thought it would. Furthermore, I think my whole mental model of how the spans were being closed and the timestamps being set was wrong. Either way, turns out `appsignal_close_span_with_timestamp` forces a recalculation of the span digest, which is something we don't want to do, as the span digest is calculated differently, from the OpenTelemetry extractor output, and the `SpanInProgress` instance does not have the necessary attributes to calculate it correctly. --- ...nt-spans-being-shown-with-the-same-body.md | 6 ++++++ ext/appsignal_extension.cpp | 19 ------------------- src/span.ts | 8 ++------ src/span_processor.ts | 2 +- 4 files changed, 9 insertions(+), 26 deletions(-) create mode 100644 .changesets/fix-different-spans-being-shown-with-the-same-body.md diff --git a/.changesets/fix-different-spans-being-shown-with-the-same-body.md b/.changesets/fix-different-spans-being-shown-with-the-same-body.md new file mode 100644 index 00000000..cc978e46 --- /dev/null +++ b/.changesets/fix-different-spans-being-shown-with-the-same-body.md @@ -0,0 +1,6 @@ +--- +bump: patch +type: fix +--- + +Fix different spans of the same category incorrectly being reported with the same body. diff --git a/ext/appsignal_extension.cpp b/ext/appsignal_extension.cpp index cba1b4e3..b21726aa 100644 --- a/ext/appsignal_extension.cpp +++ b/ext/appsignal_extension.cpp @@ -358,23 +358,6 @@ Napi::Value CloseSpan(const Napi::CallbackInfo &info) { return env.Null(); } -Napi::Value CloseSpanWithTimestamp(const Napi::CallbackInfo &info) { - Napi::Env env = info.Env(); - - Napi::External span = - info[0].As>(); - - Napi::Number endTimeSec = info[1].As(); - Napi::Number endTimeNsec = info[2].As(); - - appsignal_close_span_with_timestamp(span.Data(), - endTimeSec.Int64Value(), - endTimeNsec.Int32Value() - ); - - return env.Null(); -} - // Metrics Napi::Value SetGauge(const Napi::CallbackInfo &info) { @@ -511,8 +494,6 @@ Napi::Object CreateSpanObject(Napi::Env env, Napi::Object exports) { span.Set(Napi::String::New(env, "closeSpan"), Napi::Function::New(env, CloseSpan)); - span.Set(Napi::String::New(env, "closeSpanWithTimestamp"), - Napi::Function::New(env, CloseSpanWithTimestamp)); span.Set(Napi::String::New(env, "addSpanError"), Napi::Function::New(env, AddSpanError)); span.Set(Napi::String::New(env, "spanToJSON"), diff --git a/src/span.ts b/src/span.ts index 5bd90888..2924b595 100644 --- a/src/span.ts +++ b/src/span.ts @@ -26,12 +26,8 @@ export class Span { this.#ref = ref } - public close({ timestamp }: { timestamp?: [number, number] } = {}): this { - if (timestamp !== undefined) { - span.closeSpanWithTimestamp(this.#ref, timestamp[0], timestamp[1]) - } else { - span.closeSpan(this.#ref) - } + public close(): this { + span.closeSpan(this.#ref) return this } diff --git a/src/span_processor.ts b/src/span_processor.ts index 765f8a5e..d0c27116 100644 --- a/src/span_processor.ts +++ b/src/span_processor.ts @@ -60,7 +60,7 @@ export class SpanProcessor implements OpenTelemetrySpanProcessor { } }) - opentelemetrySpan.close({ timestamp: [span.endTime[0], span.endTime[1]] }) + opentelemetrySpan.close() } shutdown(): Promise {