mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 13:06:27 +00:00 
			
		
		
		
	fix all the array on the search get route and improve the tests
This commit is contained in:
		
							
								
								
									
										22
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										22
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							| @@ -2069,7 +2069,6 @@ dependencies = [ | ||||
|  "serde", | ||||
|  "serde-cs", | ||||
|  "serde_json", | ||||
|  "serde_url_params", | ||||
|  "sha-1", | ||||
|  "sha2", | ||||
|  "siphasher", | ||||
| @@ -2087,6 +2086,7 @@ dependencies = [ | ||||
|  "uuid", | ||||
|  "vergen", | ||||
|  "walkdir", | ||||
|  "yaup", | ||||
|  "zip", | ||||
| ] | ||||
|  | ||||
| @@ -3113,16 +3113,6 @@ dependencies = [ | ||||
|  "serde", | ||||
| ] | ||||
|  | ||||
| [[package]] | ||||
| name = "serde_url_params" | ||||
| version = "0.2.1" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "2c43307d0640738af32fe8d01e47119bc0fc8a686be470a44a586caff76dfb34" | ||||
| dependencies = [ | ||||
|  "serde", | ||||
|  "url", | ||||
| ] | ||||
|  | ||||
| [[package]] | ||||
| name = "serde_urlencoded" | ||||
| version = "0.7.1" | ||||
| @@ -3994,6 +3984,16 @@ version = "0.5.0" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "b6d12cb7a57bbf2ab670ed9545bae3648048547f9039279a89ce000208e585c1" | ||||
|  | ||||
| [[package]] | ||||
| name = "yaup" | ||||
| version = "0.1.0" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "7f8e1d3d18db742c8b9ad2f5f3c5bf5b63aa67b9933617c8f8350d39a3c173c6" | ||||
| dependencies = [ | ||||
|  "serde", | ||||
|  "url", | ||||
| ] | ||||
|  | ||||
| [[package]] | ||||
| name = "zerocopy" | ||||
| version = "0.3.0" | ||||
|   | ||||
| @@ -83,8 +83,8 @@ actix-rt = "2.7.0" | ||||
| assert-json-diff = "2.0.1" | ||||
| manifest-dir-macros = "0.1.14" | ||||
| maplit = "1.0.2" | ||||
| serde_url_params = "0.2.1" | ||||
| urlencoding = "2.1.0" | ||||
| yaup = "0.1.0" | ||||
|  | ||||
| [features] | ||||
| default = ["analytics", "mini-dashboard"] | ||||
|   | ||||
| @@ -14,7 +14,6 @@ use serde_json::Value; | ||||
| use crate::analytics::{Analytics, SearchAggregator}; | ||||
| use crate::extractors::authentication::{policies::*, GuardedData}; | ||||
| use crate::extractors::sequential_extractor::SeqHandler; | ||||
| use crate::routes::{fold_star_or, StarOr}; | ||||
|  | ||||
| pub fn configure(cfg: &mut web::ServiceConfig) { | ||||
|     cfg.service( | ||||
| @@ -30,16 +29,16 @@ pub struct SearchQueryGet { | ||||
|     q: Option<String>, | ||||
|     offset: Option<usize>, | ||||
|     limit: Option<usize>, | ||||
|     attributes_to_retrieve: Option<CS<StarOr<String>>>, | ||||
|     attributes_to_crop: Option<CS<StarOr<String>>>, | ||||
|     attributes_to_retrieve: Option<CS<String>>, | ||||
|     attributes_to_crop: Option<CS<String>>, | ||||
|     #[serde(default = "DEFAULT_CROP_LENGTH")] | ||||
|     crop_length: usize, | ||||
|     attributes_to_highlight: Option<CS<StarOr<String>>>, | ||||
|     attributes_to_highlight: Option<CS<String>>, | ||||
|     filter: Option<String>, | ||||
|     sort: Option<String>, | ||||
|     #[serde(default = "Default::default")] | ||||
|     show_matches_position: bool, | ||||
|     facets: Option<CS<StarOr<String>>>, | ||||
|     facets: Option<CS<String>>, | ||||
|     #[serde(default = "DEFAULT_HIGHLIGHT_PRE_TAG")] | ||||
|     highlight_pre_tag: String, | ||||
|     #[serde(default = "DEFAULT_HIGHLIGHT_POST_TAG")] | ||||
| @@ -62,14 +61,18 @@ impl From<SearchQueryGet> for SearchQuery { | ||||
|             q: other.q, | ||||
|             offset: other.offset, | ||||
|             limit: other.limit.unwrap_or_else(DEFAULT_SEARCH_LIMIT), | ||||
|             attributes_to_retrieve: other.attributes_to_retrieve.and_then(fold_star_or), | ||||
|             attributes_to_crop: other.attributes_to_crop.and_then(fold_star_or), | ||||
|             attributes_to_retrieve: other | ||||
|                 .attributes_to_retrieve | ||||
|                 .map(|o| o.into_iter().collect()), | ||||
|             attributes_to_crop: other.attributes_to_crop.map(|o| o.into_iter().collect()), | ||||
|             crop_length: other.crop_length, | ||||
|             attributes_to_highlight: other.attributes_to_highlight.and_then(fold_star_or), | ||||
|             attributes_to_highlight: other | ||||
|                 .attributes_to_highlight | ||||
|                 .map(|o| o.into_iter().collect()), | ||||
|             filter, | ||||
|             sort: other.sort.map(|attr| fix_sort_query_parameters(&attr)), | ||||
|             show_matches_position: other.show_matches_position, | ||||
|             facets: other.facets.and_then(fold_star_or), | ||||
|             facets: other.facets.map(|o| o.into_iter().collect()), | ||||
|             highlight_pre_tag: other.highlight_pre_tag, | ||||
|             highlight_post_tag: other.highlight_post_tag, | ||||
|             crop_marker: other.crop_marker, | ||||
|   | ||||
| @@ -221,7 +221,7 @@ impl Index<'_> { | ||||
|     } | ||||
|  | ||||
|     pub async fn search_get(&self, query: Value) -> (Value, StatusCode) { | ||||
|         let params = serde_url_params::to_string(&query).unwrap(); | ||||
|         let params = yaup::to_string(&query).unwrap(); | ||||
|         let url = format!("/indexes/{}/search?{}", encode(self.uid.as_ref()), params); | ||||
|         self.service.get(url).await | ||||
|     } | ||||
|   | ||||
| @@ -45,26 +45,18 @@ async fn search_invalid_highlight_and_crop_tags() { | ||||
|  | ||||
|     for field in fields { | ||||
|         // object | ||||
|         index | ||||
|             .search( | ||||
|                 json!({field.to_string(): {"marker": "<crop>"}}), | ||||
|                 |response, code| { | ||||
|         let (response, code) = index | ||||
|             .search_post(json!({field.to_string(): {"marker": "<crop>"}})) | ||||
|             .await; | ||||
|         assert_eq!(code, 400, "field {} passing object: {}", &field, response); | ||||
|         assert_eq!(response["code"], "bad_request"); | ||||
|                 }, | ||||
|             ) | ||||
|             .await; | ||||
|  | ||||
|         // array | ||||
|         index | ||||
|             .search( | ||||
|                 json!({field.to_string(): ["marker", "<crop>"]}), | ||||
|                 |response, code| { | ||||
|         let (response, code) = index | ||||
|             .search_post(json!({field.to_string(): ["marker", "<crop>"]})) | ||||
|             .await; | ||||
|         assert_eq!(code, 400, "field {} passing array: {}", &field, response); | ||||
|         assert_eq!(response["code"], "bad_request"); | ||||
|                 }, | ||||
|             ) | ||||
|             .await; | ||||
|     } | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -15,9 +15,9 @@ async fn formatted_contain_wildcard() { | ||||
|     index.add_documents(documents, None).await; | ||||
|     index.wait_task(1).await; | ||||
|  | ||||
|     let (response, code) = index | ||||
|         .search_post(json!({ "q": "pesti", "attributesToRetrieve": ["father", "mother"], "attributesToHighlight": ["father", "mother", "*"], "attributesToCrop": ["doggos"], "showMatchesPosition": true })) | ||||
|         .await; | ||||
|     index.search(json!({ "q": "pesti", "attributesToRetrieve": ["father", "mother"], "attributesToHighlight": ["father", "mother", "*"], "attributesToCrop": ["doggos"], "showMatchesPosition": true }), | ||||
|         |response, code| | ||||
|         { | ||||
|             assert_eq!(code, 200, "{}", response); | ||||
|             assert_eq!( | ||||
|                 response["hits"][0], | ||||
| @@ -29,6 +29,9 @@ async fn formatted_contain_wildcard() { | ||||
|                     "_matchesPosition": {"cattos": [{"start": 0, "length": 5}]}, | ||||
|                 }) | ||||
|             ); | ||||
|         } | ||||
|     ) | ||||
|     .await; | ||||
|  | ||||
|     let (response, code) = index | ||||
|         .search_post(json!({ "q": "pesti", "attributesToRetrieve": ["*"] })) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user