Skip to content

Commit

Permalink
chore: better messaging
Browse files Browse the repository at this point in the history
  • Loading branch information
mesejo committed Sep 9, 2024
1 parent 8322811 commit 6954677
Show file tree
Hide file tree
Showing 2 changed files with 32 additions and 30 deletions.
58 changes: 30 additions & 28 deletions datafusion/functions/src/unicode/substr.rs
Original file line number Diff line number Diff line change
Expand Up @@ -81,36 +81,38 @@ impl ScalarUDFImpl for SubstrFunc {
}

fn coerce_types(&self, arg_types: &[DataType]) -> Result<Vec<DataType>> {
match arg_types {
[first, second] => match (first, second) {
(
DataType::LargeUtf8 | DataType::Utf8View | DataType::Utf8,
DataType::Int64 | DataType::Int32,
) => Ok(vec![first.to_owned(), DataType::Int64]),
_ => Err(DataFusionError::Execution(format!(
"The {} function can only accept strings, but got {:?}.",
self.name(),
arg_types
))),
},
[first, second, third] => match (first, second, third) {
(
DataType::LargeUtf8 | DataType::Utf8View | DataType::Utf8,
DataType::Int64 | DataType::Int32,
DataType::Int64 | DataType::Int32,
) => Ok(vec![first.to_owned(), DataType::Int64, DataType::Int64]),
_ => Err(DataFusionError::Execution(format!(
"The {} function can only accept strings, but got {:?}.",
self.name(),
arg_types
))),
},
_ => Err(DataFusionError::Execution(format!(
"The {} function can only accept strings, but got {:?}",


if !vec![DataType::LargeUtf8, DataType::Utf8View, DataType::Utf8].contains(&arg_types[0]) {
return Err(DataFusionError::Execution(format!(
"The first argument of the {} function can only be a string, but got {:?}.",
self.name(),
arg_types[0]
)));
}

if !vec![DataType::Int64, DataType::Int32].contains(&arg_types[1]) {
return Err(DataFusionError::Execution(format!(
"The second argument of the {} function can only be an integer, but got {:?}.",
self.name(),
arg_types[1]
)));
}

if arg_types.len() == 3 && !vec![DataType::Int64, DataType::Int32].contains(&arg_types[2]) {
return Err(DataFusionError::Execution(format!(
"The third argument of the {} function can only be an integer, but got {:?}.",
self.name(),
arg_types
))),
arg_types[2]
)));
}

if arg_types.len() == 2 {
Ok(vec![arg_types[0].to_owned(), DataType::Int64])
} else {
Ok(vec![arg_types[0].to_owned(), DataType::Int64, DataType::Int64])
}

}
}

Expand Down
4 changes: 2 additions & 2 deletions datafusion/sqllogictest/test_files/functions.slt
Original file line number Diff line number Diff line change
Expand Up @@ -497,10 +497,10 @@ SELECT substr('alphabet', 3, CAST(NULL AS int))
----
NULL

statement error DataFusion error: Error during planning: Execution error: User\-defined coercion failed with Execution\("The substr function can only accept strings, but got \[Int64, Int64]\."\)
statement error DataFusion error: Error during planning: Execution error: User\-defined coercion failed with Execution\("The first argument of the substr function can only be a string, but got Int64\."\)
SELECT substr(1, 3)

statement error DataFusion error: Error during planning: Execution error: User\-defined coercion failed with Execution\("The substr function can only accept strings, but got \[Int64, Int64, Int64\]\."\)
statement error DataFusion error: Error during planning: Execution error: User\-defined coercion failed with Execution\("The first argument of the substr function can only be a string, but got Int64\."\)
SELECT substr(1, 3, 4)

query T
Expand Down

0 comments on commit 6954677

Please sign in to comment.