From 5c795bf4e46c1729bc9260713fb80d3b3d990ba6 Mon Sep 17 00:00:00 2001 From: Everett Ross Date: Tue, 28 Apr 2020 18:24:27 -0400 Subject: [PATCH] Fix uiFind matches for spans with leading 0s Signed-off-by: Everett Ross --- .../jaeger-ui/src/utils/filter-spans.test.js | 22 +++++++++++++++++++ packages/jaeger-ui/src/utils/filter-spans.tsx | 2 +- 2 files changed, 23 insertions(+), 1 deletion(-) diff --git a/packages/jaeger-ui/src/utils/filter-spans.test.js b/packages/jaeger-ui/src/utils/filter-spans.test.js index b8d61cc973..e4a054141a 100644 --- a/packages/jaeger-ui/src/utils/filter-spans.test.js +++ b/packages/jaeger-ui/src/utils/filter-spans.test.js @@ -114,6 +114,28 @@ describe('filterSpans', () => { expect(filterSpans(spanID2, spans)).toEqual(new Set([spanID2])); }); + it('should return spans whose spanID matches a filter except for leading 0s', () => { + const spanID0WithLeading0s = `00${spanID0}`; + const spanID2WithLeading0s = `00${spanID2}`; + + expect(filterSpans('spanID', spans)).toEqual(new Set([])); + expect(filterSpans(spanID0WithLeading0s, spans)).toEqual(new Set([spanID0])); + expect(filterSpans(spanID2WithLeading0s, spans)).toEqual(new Set([spanID2])); + + const spansWithLeading0s = [ + { + ...span0, + spanID: spanID0WithLeading0s, + }, + { + ...span2, + spanID: spanID2WithLeading0s, + }, + ]; + expect(filterSpans(spanID0, spansWithLeading0s)).toEqual(new Set([spanID0WithLeading0s])); + expect(filterSpans(spanID2, spansWithLeading0s)).toEqual(new Set([spanID2WithLeading0s])); + }); + it('should return spans whose operationName match a filter', () => { expect(filterSpans('operationName', spans)).toEqual(new Set([spanID0, spanID2])); expect(filterSpans('operationName0', spans)).toEqual(new Set([spanID0])); diff --git a/packages/jaeger-ui/src/utils/filter-spans.tsx b/packages/jaeger-ui/src/utils/filter-spans.tsx index 2eb4406179..d6df7876cd 100644 --- a/packages/jaeger-ui/src/utils/filter-spans.tsx +++ b/packages/jaeger-ui/src/utils/filter-spans.tsx @@ -59,7 +59,7 @@ export default function filterSpans(textFilter: string, spans: Span[] | TNil) { isTextInKeyValues(span.tags) || span.logs.some(log => isTextInKeyValues(log.fields)) || isTextInKeyValues(span.process.tags) || - includeFilters.some(filter => filter === span.spanID); + includeFilters.some(filter => filter.replace(/^0*/, '') === span.spanID.replace(/^0*/, '')); // declare as const because need to disambiguate the type const rv: Set = new Set(spans.filter(isSpanAMatch).map((span: Span) => span.spanID));