mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 04:56:28 +00:00 
			
		
		
		
	InvalidFacetDistribution returns invalid_search_facet
This commit is contained in:
		| @@ -327,7 +327,7 @@ impl ErrorCode for milli::Error { | |||||||
|                     } |                     } | ||||||
|                     UserError::PrimaryKeyCannotBeChanged(_) => Code::IndexPrimaryKeyAlreadyExists, |                     UserError::PrimaryKeyCannotBeChanged(_) => Code::IndexPrimaryKeyAlreadyExists, | ||||||
|                     UserError::SortRankingRuleMissing => Code::InvalidSearchSort, |                     UserError::SortRankingRuleMissing => Code::InvalidSearchSort, | ||||||
|                     UserError::InvalidFacetsDistribution { .. } => Code::BadRequest, |                     UserError::InvalidFacetsDistribution { .. } => Code::InvalidSearchFacets, | ||||||
|                     UserError::InvalidSortableAttribute { .. } => Code::InvalidSearchSort, |                     UserError::InvalidSortableAttribute { .. } => Code::InvalidSearchSort, | ||||||
|                     UserError::CriterionError(_) => Code::InvalidSettingsRankingRules, |                     UserError::CriterionError(_) => Code::InvalidSettingsRankingRules, | ||||||
|                     UserError::InvalidGeoField { .. } => Code::InvalidDocumentGeoField, |                     UserError::InvalidGeoField { .. } => Code::InvalidDocumentGeoField, | ||||||
|   | |||||||
| @@ -321,6 +321,37 @@ async fn search_bad_facets() { | |||||||
|     // Can't make the `attributes_to_highlight` fail with a get search since it'll accept anything as an array of strings. |     // Can't make the `attributes_to_highlight` fail with a get search since it'll accept anything as an array of strings. | ||||||
| } | } | ||||||
|  |  | ||||||
|  | #[actix_rt::test] | ||||||
|  | async fn search_non_filterable_facets() { | ||||||
|  |     let server = Server::new().await; | ||||||
|  |     let index = server.index("test"); | ||||||
|  |     index.update_settings(json!({"filterableAttributes": ["title"]})).await; | ||||||
|  |     // Wait for the settings update to complete | ||||||
|  |     index.wait_task(0).await; | ||||||
|  |  | ||||||
|  |     let (response, code) = index.search_post(json!({"facets": ["doggo"]})).await; | ||||||
|  |     snapshot!(code, @"400 Bad Request"); | ||||||
|  |     snapshot!(json_string!(response), @r###" | ||||||
|  |     { | ||||||
|  |       "message": "Invalid facet distribution, the fields `doggo` are not set as filterable.", | ||||||
|  |       "code": "invalid_search_facets", | ||||||
|  |       "type": "invalid_request", | ||||||
|  |       "link": "https://docs.meilisearch.com/errors#invalid-search-facets" | ||||||
|  |     } | ||||||
|  |     "###); | ||||||
|  |  | ||||||
|  |     let (response, code) = index.search_get("facets=doggo").await; | ||||||
|  |     snapshot!(code, @"400 Bad Request"); | ||||||
|  |     snapshot!(json_string!(response), @r###" | ||||||
|  |     { | ||||||
|  |       "message": "Invalid facet distribution, the fields `doggo` are not set as filterable.", | ||||||
|  |       "code": "invalid_search_facets", | ||||||
|  |       "type": "invalid_request", | ||||||
|  |       "link": "https://docs.meilisearch.com/errors#invalid-search-facets" | ||||||
|  |     } | ||||||
|  |     "###); | ||||||
|  | } | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
| async fn search_bad_highlight_pre_tag() { | async fn search_bad_highlight_pre_tag() { | ||||||
|     let server = Server::new().await; |     let server = Server::new().await; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user