From bcceaac587fbcd2d896746d7f05f40a72030bae6 Mon Sep 17 00:00:00 2001 From: Nicolas Marsal <3530655+hakkanicko@users.noreply.github.com> Date: Fri, 2 Aug 2024 15:46:27 +0200 Subject: [PATCH] fix: traceFlags test in isHeadSampled function The flag wasn't tested as a bit, but as a whole value For now, since there is only one flag in TraceFlags, it works, but it won't in the future if a flag is added --- README.md | 4 ++-- src/sampling.ts | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/README.md b/README.md index fd7116f..78f4468 100644 --- a/README.md +++ b/README.md @@ -215,9 +215,9 @@ Tail Sampling on the other hand is done at the end. Because we record every sing Example: ```typescript -const tailSampler = (localTrace: LocalTrace): boolean => { +const tailSampler = (traceInfo: LocalTrace): boolean => { const localRootSpan = traceInfo.localRootSpan as unknown as ReadableSpan - return localRootSpan.spanContext().traceFlags === TraceFlags.SAMPLED + return (localRootSpan.spanContext().traceFlags & TraceFlags.SAMPLED) === TraceFlags.SAMPLED } ``` diff --git a/src/sampling.ts b/src/sampling.ts index 4e05cd8..f8bb05d 100644 --- a/src/sampling.ts +++ b/src/sampling.ts @@ -17,7 +17,7 @@ export function multiTailSampler(samplers: TailSampleFn[]): TailSampleFn { export const isHeadSampled: TailSampleFn = (traceInfo) => { const localRootSpan = traceInfo.localRootSpan as unknown as ReadableSpan - return localRootSpan.spanContext().traceFlags === TraceFlags.SAMPLED + return (localRootSpan.spanContext().traceFlags & TraceFlags.SAMPLED) === TraceFlags.SAMPLED } export const isRootErrorSpan: TailSampleFn = (traceInfo) => {