mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-26 05:26:27 +00:00 
			
		
		
		
	Merge #3942
3942: Normalize for the search the facets values r=ManyTheFish a=Kerollmops This PR improves and fixes the search for facet values feature. Searching for _bre_ wasn't returning facet values like _brévent_ or _brô_. The issue was related to the fact that facets are normalized but not in the same way as the `searchableAttributes` are. We decided to normalize them further and add another intermediate database where the key is the normalized facet value, and the value is a set of the non-normalized facets. We then use these non-normalized ones to get the correct counts by fetching the associated databases. ### What's missing in this PR? - [x] Apply the change to the whole set of `SearchForFacetValue::execute` conditions. - [x] Factorize the code that does an intermediate normalized value fetch in a function. - [x] Add or modify the search for facet value test. Co-authored-by: Clément Renault <clement@meilisearch.com> Co-authored-by: Kerollmops <clement@meilisearch.com>
This commit is contained in:
		| @@ -1,3 +1,4 @@ | ||||
| use meili_snap::snapshot; | ||||
| use once_cell::sync::Lazy; | ||||
| use serde_json::{json, Value}; | ||||
|  | ||||
| @@ -56,6 +57,54 @@ async fn simple_facet_search() { | ||||
|     assert_eq!(response["facetHits"].as_array().unwrap().len(), 1); | ||||
| } | ||||
|  | ||||
| #[actix_rt::test] | ||||
| async fn advanced_facet_search() { | ||||
|     let server = Server::new().await; | ||||
|     let index = server.index("test"); | ||||
|  | ||||
|     let documents = DOCUMENTS.clone(); | ||||
|     index.update_settings_filterable_attributes(json!(["genres"])).await; | ||||
|     index.update_settings_typo_tolerance(json!({ "enabled": false })).await; | ||||
|     index.add_documents(documents, None).await; | ||||
|     index.wait_task(2).await; | ||||
|  | ||||
|     let (response, code) = | ||||
|         index.facet_search(json!({"facetName": "genres", "facetQuery": "adventre"})).await; | ||||
|  | ||||
|     snapshot!(code, @"200 OK"); | ||||
|     snapshot!(response["facetHits"].as_array().unwrap().len(), @"0"); | ||||
|  | ||||
|     let (response, code) = | ||||
|         index.facet_search(json!({"facetName": "genres", "facetQuery": "àdventure"})).await; | ||||
|  | ||||
|     snapshot!(code, @"200 OK"); | ||||
|     snapshot!(response["facetHits"].as_array().unwrap().len(), @"1"); | ||||
| } | ||||
|  | ||||
| #[actix_rt::test] | ||||
| async fn more_advanced_facet_search() { | ||||
|     let server = Server::new().await; | ||||
|     let index = server.index("test"); | ||||
|  | ||||
|     let documents = DOCUMENTS.clone(); | ||||
|     index.update_settings_filterable_attributes(json!(["genres"])).await; | ||||
|     index.update_settings_typo_tolerance(json!({ "disableOnWords": ["adventre"] })).await; | ||||
|     index.add_documents(documents, None).await; | ||||
|     index.wait_task(2).await; | ||||
|  | ||||
|     let (response, code) = | ||||
|         index.facet_search(json!({"facetName": "genres", "facetQuery": "adventre"})).await; | ||||
|  | ||||
|     snapshot!(code, @"200 OK"); | ||||
|     snapshot!(response["facetHits"].as_array().unwrap().len(), @"0"); | ||||
|  | ||||
|     let (response, code) = | ||||
|         index.facet_search(json!({"facetName": "genres", "facetQuery": "adventure"})).await; | ||||
|  | ||||
|     snapshot!(code, @"200 OK"); | ||||
|     snapshot!(response["facetHits"].as_array().unwrap().len(), @"1"); | ||||
| } | ||||
|  | ||||
| #[actix_rt::test] | ||||
| async fn non_filterable_facet_search_error() { | ||||
|     let server = Server::new().await; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user