mirror of
https://github.com/meilisearch/MeiliSearch
synced 2025-01-11 22:14:32 +01:00
improve and test the sort error message
This commit is contained in:
parent
0ee67bb7d1
commit
d9eba9d145
@ -20,12 +20,12 @@ impl fmt::Display for AscDescError {
|
|||||||
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||||
match self {
|
match self {
|
||||||
Self::InvalidSyntax { name } => {
|
Self::InvalidSyntax { name } => {
|
||||||
write!(f, "invalid asc/desc syntax for {}", name)
|
write!(f, "invalid asc/desc syntax for {}.", name)
|
||||||
}
|
}
|
||||||
Self::ReservedKeyword { name } => {
|
Self::ReservedKeyword { name } => {
|
||||||
write!(
|
write!(
|
||||||
f,
|
f,
|
||||||
"{} is a reserved keyword and thus can't be used as a asc/desc rule",
|
"{} is a reserved keyword and thus can't be used as a asc/desc rule.",
|
||||||
name
|
name
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
@ -128,8 +128,6 @@ impl AscDesc {
|
|||||||
impl FromStr for AscDesc {
|
impl FromStr for AscDesc {
|
||||||
type Err = AscDescError;
|
type Err = AscDescError;
|
||||||
|
|
||||||
/// Since we don't know if this was deserialized for a criterion or a sort we just return a
|
|
||||||
/// string and let the caller create his own error.
|
|
||||||
fn from_str(text: &str) -> Result<AscDesc, Self::Err> {
|
fn from_str(text: &str) -> Result<AscDesc, Self::Err> {
|
||||||
match text.rsplit_once(':') {
|
match text.rsplit_once(':') {
|
||||||
Some((left, "asc")) => Ok(AscDesc::Asc(left.parse()?)),
|
Some((left, "asc")) => Ok(AscDesc::Asc(left.parse()?)),
|
||||||
@ -156,10 +154,10 @@ impl From<AscDescError> for SortError {
|
|||||||
SortError::BadGeoPointUsage { name }
|
SortError::BadGeoPointUsage { name }
|
||||||
}
|
}
|
||||||
AscDescError::ReservedKeyword { name } if &name == "_geo" => {
|
AscDescError::ReservedKeyword { name } if &name == "_geo" => {
|
||||||
SortError::ReservedNameForSettings { name: "_geoPoint".to_string() }
|
SortError::ReservedNameForSettings { name }
|
||||||
}
|
}
|
||||||
AscDescError::ReservedKeyword { name } if name.starts_with("_geoRadius") => {
|
AscDescError::ReservedKeyword { name } if name.starts_with("_geoRadius") => {
|
||||||
SortError::ReservedNameForFilter { name: "_geoRadius".to_string() }
|
SortError::ReservedNameForFilter { name: String::from("_geoRadius") }
|
||||||
}
|
}
|
||||||
AscDescError::ReservedKeyword { name } => SortError::ReservedName { name },
|
AscDescError::ReservedKeyword { name } => SortError::ReservedName { name },
|
||||||
}
|
}
|
||||||
@ -173,34 +171,26 @@ impl fmt::Display for SortError {
|
|||||||
write!(
|
write!(
|
||||||
f,
|
f,
|
||||||
"invalid syntax for the `_geoPoint` parameter: `{}`. \
|
"invalid syntax for the `_geoPoint` parameter: `{}`. \
|
||||||
Usage: `_geoPoint(latitude, longitude):asc`",
|
Usage: `_geoPoint(latitude, longitude):asc`.",
|
||||||
name
|
name
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
Self::InvalidName { name } => {
|
Self::InvalidName { name } => {
|
||||||
write!(f, "invalid syntax for the sort parameter {}", name)
|
write!(f, "invalid syntax for the sort parameter `{}`.", name)
|
||||||
}
|
}
|
||||||
Self::ReservedName { name } => {
|
Self::ReservedName { name } => {
|
||||||
write!(
|
write!(
|
||||||
f,
|
f,
|
||||||
"{} is a reserved keyword and thus can't be used as a sort expression",
|
"{} is a reserved keyword and thus can't be used as a sort expression.",
|
||||||
name
|
name
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
Self::ReservedNameForSettings { name } => {
|
Self::ReservedNameForSettings { name } | Self::ReservedNameForFilter { name } => {
|
||||||
write!(
|
write!(
|
||||||
f,
|
f,
|
||||||
"{} is a reserved keyword and thus can't be used as a sort expression. \
|
"`{}` is a reserved keyword and thus can't be used as a sort expression. \
|
||||||
{} can only be used in the settings",
|
Use the `_geoPoint(latitude, longitude)` built-in rule to sort on `_geo` field coordinates.",
|
||||||
name, name
|
name,
|
||||||
)
|
|
||||||
}
|
|
||||||
Self::ReservedNameForFilter { name } => {
|
|
||||||
write!(
|
|
||||||
f,
|
|
||||||
"{} is a reserved keyword and thus can't be used as a sort expression. \
|
|
||||||
{} can only be used for filtering at search time",
|
|
||||||
name, name
|
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -299,4 +289,42 @@ mod tests {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn sort_error_message() {
|
||||||
|
let errors = [
|
||||||
|
(
|
||||||
|
AscDescError::InvalidSyntax { name: S("truc:machin") },
|
||||||
|
S("invalid syntax for the sort parameter `truc:machin`."),
|
||||||
|
),
|
||||||
|
(
|
||||||
|
AscDescError::InvalidSyntax { name: S("hello:world") },
|
||||||
|
S("invalid syntax for the sort parameter `hello:world`."),
|
||||||
|
),
|
||||||
|
(
|
||||||
|
AscDescError::ReservedKeyword { name: S("_geo") },
|
||||||
|
S("`_geo` is a reserved keyword and thus can't be used as a sort expression. Use the `_geoPoint(latitude, longitude)` built-in rule to sort on `_geo` field coordinates."),
|
||||||
|
),
|
||||||
|
(
|
||||||
|
AscDescError::ReservedKeyword { name: S("_geoDistance") },
|
||||||
|
S("_geoDistance is a reserved keyword and thus can't be used as a sort expression.")
|
||||||
|
),
|
||||||
|
(
|
||||||
|
AscDescError::ReservedKeyword { name: S("_geoRadius(12, 13)") },
|
||||||
|
S("`_geoRadius` is a reserved keyword and thus can't be used as a sort expression. Use the `_geoPoint(latitude, longitude)` built-in rule to sort on `_geo` field coordinates."),
|
||||||
|
),
|
||||||
|
];
|
||||||
|
|
||||||
|
for (asc_desc_error, expected_message) in errors {
|
||||||
|
let sort_error = SortError::from(asc_desc_error);
|
||||||
|
assert_eq!(
|
||||||
|
sort_error.to_string(),
|
||||||
|
expected_message,
|
||||||
|
"was expecting {} for the error {:?} but instead got {}",
|
||||||
|
expected_message,
|
||||||
|
sort_error,
|
||||||
|
sort_error.to_string()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user