From 3a1532a695b313083e750d353efcd05e1bda6f0e Mon Sep 17 00:00:00 2001 From: trinity-1686a Date: Wed, 23 Oct 2024 15:15:17 +0200 Subject: [PATCH] fix unit conversion in jaeger http search endpoint (#5519) --- .../quickwit-serve/src/jaeger_api/model.rs | 2 ++ .../src/jaeger_api/rest_handler.rs | 20 +++++++++++++++++-- 2 files changed, 20 insertions(+), 2 deletions(-) diff --git a/quickwit/quickwit-serve/src/jaeger_api/model.rs b/quickwit/quickwit-serve/src/jaeger_api/model.rs index 502e4d251a6..917d31fc68b 100644 --- a/quickwit/quickwit-serve/src/jaeger_api/model.rs +++ b/quickwit/quickwit-serve/src/jaeger_api/model.rs @@ -55,9 +55,11 @@ pub struct TracesSearchQueryParams { pub service: Option, #[serde(default)] pub operation: Option, + // these are microsecond precision pub start: Option, pub end: Option, pub tags: Option, + // these are unit-suffixed numbers. in practice we only support precision up to the ms pub min_duration: Option, pub max_duration: Option, pub lookback: Option, diff --git a/quickwit/quickwit-serve/src/jaeger_api/rest_handler.rs b/quickwit/quickwit-serve/src/jaeger_api/rest_handler.rs index 15d76413f47..544c30afda4 100644 --- a/quickwit/quickwit-serve/src/jaeger_api/rest_handler.rs +++ b/quickwit/quickwit-serve/src/jaeger_api/rest_handler.rs @@ -248,8 +248,12 @@ async fn jaeger_traces_search( service_name: search_params.service.unwrap_or_default(), operation_name: search_params.operation.unwrap_or_default(), tags, - start_time_min: search_params.start.map(to_well_known_timestamp), - start_time_max: search_params.end.map(to_well_known_timestamp), + start_time_min: search_params + .start + .map(|ts| to_well_known_timestamp(ts * 1000)), + start_time_max: search_params + .end + .map(|ts| to_well_known_timestamp(ts * 1000)), duration_min, duration_max, num_traces: search_params.limit.unwrap_or(DEFAULT_NUMBER_OF_TRACES), @@ -449,6 +453,18 @@ mod tests { "{\"type\":\"term\",\"field\":\"resource_attributes.tag.second\",\"value\":\"\ true\"}" )); + assert!(req.query_ast.contains( + "{\"type\":\"term\",\"field\":\"resource_attributes.tag.second\",\"value\":\"\ + true\"}" + )); + // no lowerbound because minDuration < 1ms, + assert!(req.query_ast.contains( + "{\"type\":\"range\",\"field\":\"span_duration_millis\",\"lower_bound\":\"\ + Unbounded\",\"upper_bound\":{\"Included\":1200}}" + )); + assert_eq!(req.start_timestamp, Some(1702352106)); + // TODO(trinity) i think we have an off by 1 here, imo this should be rounded up + assert_eq!(req.end_timestamp, Some(1702373706)); assert_eq!( req.index_id_patterns, vec![OTEL_TRACES_INDEX_ID.to_string()]