mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-26 13:36:27 +00:00 
			
		
		
		
	Improve errors and introduce a new InvalidSearchDistinct error code
This commit is contained in:
		| @@ -134,6 +134,17 @@ only composed of alphanumeric characters (a-z A-Z 0-9), hyphens (-) and undersco | ||||
|         } | ||||
|     )] | ||||
|     InvalidSortableAttribute { field: String, valid_fields: BTreeSet<String>, hidden_fields: bool }, | ||||
|     #[error("Attribute `{}` is not filterable and thus, cannot be used as distinct attribute. {}", | ||||
|         .field, | ||||
|         match .valid_fields.is_empty() { | ||||
|             true => "This index does not have configured filterable attributes.".to_string(), | ||||
|             false => format!("Available filterable attributes are: `{}{}`.", | ||||
|                     valid_fields.iter().map(AsRef::as_ref).collect::<Vec<&str>>().join(", "), | ||||
|                     .hidden_fields.then_some(", <..hidden-attributes>").unwrap_or(""), | ||||
|                 ), | ||||
|         } | ||||
|     )] | ||||
|     InvalidDistinctAttribute { field: String, valid_fields: BTreeSet<String>, hidden_fields: bool }, | ||||
|     #[error("Attribute `{}` is not facet-searchable. {}", | ||||
|         .field, | ||||
|         match .valid_fields.is_empty() { | ||||
|   | ||||
| @@ -11,8 +11,8 @@ use self::new::{execute_vector_search, PartialSearchResult}; | ||||
| use crate::score_details::{ScoreDetails, ScoringStrategy}; | ||||
| use crate::vector::Embedder; | ||||
| use crate::{ | ||||
|     execute_search, filtered_universe, AscDesc, DefaultSearchLogger, DocumentId, Index, Result, | ||||
|     SearchContext, TimeBudget, | ||||
|     execute_search, filtered_universe, AscDesc, DefaultSearchLogger, DocumentId, Error, Index, | ||||
|     Result, SearchContext, TimeBudget, UserError, | ||||
| }; | ||||
|  | ||||
| // Building these factories is not free. | ||||
| @@ -177,9 +177,15 @@ impl<'a> Search<'a> { | ||||
|         } | ||||
|  | ||||
|         if let Some(distinct) = &self.distinct { | ||||
|             if !ctx.index.filterable_fields(ctx.txn)?.contains(distinct) { | ||||
|                 // TODO return a real error message | ||||
|                 panic!("Distinct search field is not a filterable attribute"); | ||||
|             let filterable_fields = ctx.index.filterable_fields(ctx.txn)?; | ||||
|             if !filterable_fields.contains(distinct) { | ||||
|                 let (valid_fields, hidden_fields) = | ||||
|                     ctx.index.remove_hidden_fields(ctx.txn, filterable_fields)?; | ||||
|                 return Err(Error::UserError(UserError::InvalidDistinctAttribute { | ||||
|                     field: distinct.clone(), | ||||
|                     valid_fields, | ||||
|                     hidden_fields, | ||||
|                 })); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user