From 25d45970e6c545f4963cf3895399ec34dae86802 Mon Sep 17 00:00:00 2001 From: Xiangjin Date: Fri, 27 Oct 2023 15:34:03 +0800 Subject: [PATCH 1/2] fix(expr): include data type in parse error message --- src/expr/impl/src/scalar/cast.rs | 14 +++++++++----- 1 file changed, 9 insertions(+), 5 deletions(-) diff --git a/src/expr/impl/src/scalar/cast.rs b/src/expr/impl/src/scalar/cast.rs index f22b643bb9a09..ae2ed50472b86 100644 --- a/src/expr/impl/src/scalar/cast.rs +++ b/src/expr/impl/src/scalar/cast.rs @@ -37,14 +37,14 @@ use risingwave_pb::expr::expr_node::PbType; #[function("cast(varchar) -> timestamp")] #[function("cast(varchar) -> interval")] #[function("cast(varchar) -> jsonb")] -pub fn str_parse(elem: &str) -> Result +pub fn str_parse(elem: &str, ctx: &Context) -> Result where T: FromStr, ::Err: std::fmt::Display, { - elem.trim() - .parse() - .map_err(|err: ::Err| ExprError::Parse(err.to_string().into())) + elem.trim().parse().map_err(|err: ::Err| { + ExprError::Parse(format!("{} {}", ctx.return_type, err).into()) + }) } // TODO: introduce `FromBinary` and support all types @@ -521,7 +521,11 @@ mod tests { async fn test_unary() { test_unary_bool::(|x| !x, PbType::Not).await; test_unary_date::(|x| try_cast(x).unwrap(), PbType::Cast).await; - test_str_to_int16::(|x| str_parse(x).unwrap()).await; + let ctx_str_to_int16 = Context { + arg_types: vec![DataType::Varchar], + return_type: DataType::Int16, + }; + test_str_to_int16::(|x| str_parse(x, &ctx_str_to_int16).unwrap()).await; } #[tokio::test] From 86f88c90f588a984632e184b050439f55783e46a Mon Sep 17 00:00:00 2001 From: Xiangjin Date: Sun, 29 Oct 2023 19:11:03 +0800 Subject: [PATCH 2/2] update planner test expectations --- .../planner_test/tests/testdata/output/range_scan.yaml | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/frontend/planner_test/tests/testdata/output/range_scan.yaml b/src/frontend/planner_test/tests/testdata/output/range_scan.yaml index d16b98f101d3b..f95075c8823a8 100644 --- a/src/frontend/planner_test/tests/testdata/output/range_scan.yaml +++ b/src/frontend/planner_test/tests/testdata/output/range_scan.yaml @@ -42,12 +42,12 @@ - create_table_and_mv sql: | SELECT * FROM orders_count_by_user WHERE user_id = 'a' - batch_error: 'Expr error: Parse error: invalid digit found in string' + batch_error: 'Expr error: Parse error: bigint invalid digit found in string' - before: - create_table_and_mv sql: | SELECT * FROM orders_count_by_user WHERE user_id > 'a' - batch_error: 'Expr error: Parse error: invalid digit found in string' + batch_error: 'Expr error: Parse error: bigint invalid digit found in string' - before: - create_table_and_mv sql: | @@ -129,7 +129,7 @@ - create_table_and_mv sql: | SELECT * FROM orders_count_by_user WHERE user_id in ('42', '43.0') - batch_error: 'Expr error: Parse error: invalid digit found in string' + batch_error: 'Expr error: Parse error: bigint invalid digit found in string' - before: - create_table_and_mv sql: |