mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-24 20:46:27 +00:00 
			
		
		
		
	Merge #4667
4667: Frequency matching strategy r=Kerollmops a=ManyTheFish # Pull Request ## Related issue Fixes #3773 ## What does this PR do? - add test for matching strategy - implement frequency matching strategy See the [PRD for more details](https://www.notion.so/meilisearch/Frequency-Matching-Strategy-0f3ba08833a442a39590a53a1505ab00). [Public API](https://www.notion.so/meilisearch/frequency-matching-strategy-89868fb7fc584026bc56e378eb854a7f). Co-authored-by: ManyTheFish <many@meilisearch.com>
This commit is contained in:
		| @@ -505,7 +505,7 @@ async fn search_bad_matching_strategy() { | ||||
|     snapshot!(code, @"400 Bad Request"); | ||||
|     snapshot!(json_string!(response), @r###" | ||||
|     { | ||||
|       "message": "Unknown value `doggo` at `.matchingStrategy`: expected one of `last`, `all`", | ||||
|       "message": "Unknown value `doggo` at `.matchingStrategy`: expected one of `last`, `all`, `frequency`", | ||||
|       "code": "invalid_search_matching_strategy", | ||||
|       "type": "invalid_request", | ||||
|       "link": "https://docs.meilisearch.com/errors#invalid_search_matching_strategy" | ||||
| @@ -527,7 +527,7 @@ async fn search_bad_matching_strategy() { | ||||
|     snapshot!(code, @"400 Bad Request"); | ||||
|     snapshot!(json_string!(response), @r###" | ||||
|     { | ||||
|       "message": "Unknown value `doggo` for parameter `matchingStrategy`: expected one of `last`, `all`", | ||||
|       "message": "Unknown value `doggo` for parameter `matchingStrategy`: expected one of `last`, `all`, `frequency`", | ||||
|       "code": "invalid_search_matching_strategy", | ||||
|       "type": "invalid_request", | ||||
|       "link": "https://docs.meilisearch.com/errors#invalid_search_matching_strategy" | ||||
|   | ||||
							
								
								
									
										128
									
								
								meilisearch/tests/search/matching_strategy.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										128
									
								
								meilisearch/tests/search/matching_strategy.rs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,128 @@ | ||||
| use meili_snap::snapshot; | ||||
| use once_cell::sync::Lazy; | ||||
|  | ||||
| use crate::common::index::Index; | ||||
| use crate::common::{Server, Value}; | ||||
| use crate::json; | ||||
|  | ||||
| async fn index_with_documents<'a>(server: &'a Server, documents: &Value) -> Index<'a> { | ||||
|     let index = server.index("test"); | ||||
|  | ||||
|     index.add_documents(documents.clone(), None).await; | ||||
|     index.wait_task(0).await; | ||||
|     index | ||||
| } | ||||
|  | ||||
| static SIMPLE_SEARCH_DOCUMENTS: Lazy<Value> = Lazy::new(|| { | ||||
|     json!([ | ||||
|     { | ||||
|         "title": "Shazam!", | ||||
|         "id": "1", | ||||
|     }, | ||||
|     { | ||||
|         "title": "Captain Planet", | ||||
|         "id": "2", | ||||
|     }, | ||||
|     { | ||||
|         "title": "Captain Marvel", | ||||
|         "id": "3", | ||||
|     }, | ||||
|     { | ||||
|         "title": "a Captain Marvel ersatz", | ||||
|         "id": "4" | ||||
|     }, | ||||
|     { | ||||
|         "title": "He's not part of the Marvel Cinematic Universe", | ||||
|         "id": "5" | ||||
|     }, | ||||
|     { | ||||
|         "title": "a Shazam ersatz, but better than Captain Planet", | ||||
|         "id": "6" | ||||
|     }, | ||||
|     { | ||||
|         "title": "Capitain CAAAAAVEEERNE!!!!", | ||||
|         "id": "7" | ||||
|     } | ||||
|     ]) | ||||
| }); | ||||
|  | ||||
| #[actix_rt::test] | ||||
| async fn simple_search() { | ||||
|     let server = Server::new().await; | ||||
|     let index = index_with_documents(&server, &SIMPLE_SEARCH_DOCUMENTS).await; | ||||
|  | ||||
|     index | ||||
|         .search(json!({"q": "Captain Marvel", "matchingStrategy": "last", "attributesToRetrieve": ["id"]}), |response, code| { | ||||
|             snapshot!(code, @"200 OK"); | ||||
|             snapshot!(response["hits"], @r###"[{"id":"3"},{"id":"4"},{"id":"2"},{"id":"6"},{"id":"7"}]"###); | ||||
|         }) | ||||
|         .await; | ||||
|  | ||||
|     index | ||||
|         .search(json!({"q": "Captain Marvel", "matchingStrategy": "all", "attributesToRetrieve": ["id"]}), |response, code| { | ||||
|             snapshot!(code, @"200 OK"); | ||||
|             snapshot!(response["hits"], @r###"[{"id":"3"},{"id":"4"}]"###); | ||||
|         }) | ||||
|         .await; | ||||
|  | ||||
|     index | ||||
|         .search(json!({"q": "Captain Marvel", "matchingStrategy": "frequency", "attributesToRetrieve": ["id"]}), |response, code| { | ||||
|             snapshot!(code, @"200 OK"); | ||||
|             snapshot!(response["hits"], @r###"[{"id":"3"},{"id":"4"},{"id":"5"}]"###); | ||||
|         }) | ||||
|         .await; | ||||
| } | ||||
|  | ||||
| #[actix_rt::test] | ||||
| async fn search_with_typo() { | ||||
|     let server = Server::new().await; | ||||
|     let index = index_with_documents(&server, &SIMPLE_SEARCH_DOCUMENTS).await; | ||||
|  | ||||
|     index | ||||
|         .search(json!({"q": "Capitain Marvel", "matchingStrategy": "last", "attributesToRetrieve": ["id"]}), |response, code| { | ||||
|             snapshot!(code, @"200 OK"); | ||||
|             snapshot!(response["hits"], @r###"[{"id":"3"},{"id":"4"},{"id":"7"},{"id":"2"},{"id":"6"}]"###); | ||||
|         }) | ||||
|         .await; | ||||
|  | ||||
|     index | ||||
|         .search(json!({"q": "Capitain Marvel", "matchingStrategy": "all", "attributesToRetrieve": ["id"]}), |response, code| { | ||||
|             snapshot!(code, @"200 OK"); | ||||
|             snapshot!(response["hits"], @r###"[{"id":"3"},{"id":"4"}]"###); | ||||
|         }) | ||||
|         .await; | ||||
|  | ||||
|     index | ||||
|         .search(json!({"q": "Capitain Marvel", "matchingStrategy": "frequency", "attributesToRetrieve": ["id"]}), |response, code| { | ||||
|             snapshot!(code, @"200 OK"); | ||||
|             snapshot!(response["hits"], @r###"[{"id":"3"},{"id":"4"},{"id":"5"}]"###); | ||||
|         }) | ||||
|         .await; | ||||
| } | ||||
|  | ||||
| #[actix_rt::test] | ||||
| async fn search_with_unknown_word() { | ||||
|     let server = Server::new().await; | ||||
|     let index = index_with_documents(&server, &SIMPLE_SEARCH_DOCUMENTS).await; | ||||
|  | ||||
|     index | ||||
|         .search(json!({"q": "Captain Supercopter Marvel", "matchingStrategy": "last", "attributesToRetrieve": ["id"]}), |response, code| { | ||||
|             snapshot!(code, @"200 OK"); | ||||
|             snapshot!(response["hits"], @r###"[{"id":"2"},{"id":"3"},{"id":"4"},{"id":"6"},{"id":"7"}]"###); | ||||
|         }) | ||||
|         .await; | ||||
|  | ||||
|     index | ||||
|         .search(json!({"q": "Captain Supercopter Marvel", "matchingStrategy": "all", "attributesToRetrieve": ["id"]}), |response, code| { | ||||
|             snapshot!(code, @"200 OK"); | ||||
|             snapshot!(response["hits"], @"[]"); | ||||
|         }) | ||||
|         .await; | ||||
|  | ||||
|     index | ||||
|         .search(json!({"q": "Captain Supercopter Marvel", "matchingStrategy": "frequency", "attributesToRetrieve": ["id"]}), |response, code| { | ||||
|             snapshot!(code, @"200 OK"); | ||||
|             snapshot!(response["hits"], @r###"[{"id":"3"},{"id":"4"},{"id":"5"}]"###); | ||||
|         }) | ||||
|         .await; | ||||
| } | ||||
| @@ -7,6 +7,7 @@ mod facet_search; | ||||
| mod formatted; | ||||
| mod geo; | ||||
| mod hybrid; | ||||
| mod matching_strategy; | ||||
| mod multi; | ||||
| mod pagination; | ||||
| mod restrict_searchable; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user