mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 13:06:27 +00:00 
			
		
		
		
	Change lacking errors
This commit is contained in:
		| @@ -53,7 +53,6 @@ pub enum Code { | |||||||
|     IndexAlreadyExists, |     IndexAlreadyExists, | ||||||
|     IndexNotFound, |     IndexNotFound, | ||||||
|     InvalidIndexUid, |     InvalidIndexUid, | ||||||
|     OpenIndex, |  | ||||||
|  |  | ||||||
|     // invalid state error |     // invalid state error | ||||||
|     InvalidState, |     InvalidState, | ||||||
| @@ -70,13 +69,16 @@ pub enum Code { | |||||||
|  |  | ||||||
|     BadParameter, |     BadParameter, | ||||||
|     BadRequest, |     BadRequest, | ||||||
|  |     DatabaseSizeLimitReached, | ||||||
|     DocumentNotFound, |     DocumentNotFound, | ||||||
|     Internal, |     Internal, | ||||||
|     InvalidGeoField, |     InvalidGeoField, | ||||||
|     InvalidRankingRule, |     InvalidRankingRule, | ||||||
|  |     InvalidStore, | ||||||
|     InvalidToken, |     InvalidToken, | ||||||
|     MissingAuthorizationHeader, |     MissingAuthorizationHeader, | ||||||
|     NotFound, |     NoSpaceLeftOnDevice, | ||||||
|  |     DumpNotFound, | ||||||
|     TaskNotFound, |     TaskNotFound, | ||||||
|     PayloadTooLarge, |     PayloadTooLarge, | ||||||
|     RetrieveDocument, |     RetrieveDocument, | ||||||
| @@ -100,14 +102,13 @@ impl Code { | |||||||
|         match self { |         match self { | ||||||
|             // index related errors |             // index related errors | ||||||
|             // create index is thrown on internal error while creating an index. |             // create index is thrown on internal error while creating an index. | ||||||
|             CreateIndex => ErrCode::internal("index_creation_failed", StatusCode::BAD_REQUEST), |             CreateIndex => { | ||||||
|  |                 ErrCode::internal("index_creation_failed", StatusCode::INTERNAL_SERVER_ERROR) | ||||||
|  |             } | ||||||
|             IndexAlreadyExists => ErrCode::invalid("index_already_exists", StatusCode::CONFLICT), |             IndexAlreadyExists => ErrCode::invalid("index_already_exists", StatusCode::CONFLICT), | ||||||
|             // thrown when requesting an unexisting index |             // thrown when requesting an unexisting index | ||||||
|             IndexNotFound => ErrCode::invalid("index_not_found", StatusCode::NOT_FOUND), |             IndexNotFound => ErrCode::invalid("index_not_found", StatusCode::NOT_FOUND), | ||||||
|             InvalidIndexUid => ErrCode::invalid("invalid_index_uid", StatusCode::BAD_REQUEST), |             InvalidIndexUid => ErrCode::invalid("invalid_index_uid", StatusCode::BAD_REQUEST), | ||||||
|             OpenIndex => { |  | ||||||
|                 ErrCode::internal("index_not_accessible", StatusCode::INTERNAL_SERVER_ERROR) |  | ||||||
|             } |  | ||||||
|  |  | ||||||
|             // invalid state error |             // invalid state error | ||||||
|             InvalidState => ErrCode::internal("invalid_state", StatusCode::INTERNAL_SERVER_ERROR), |             InvalidState => ErrCode::internal("invalid_state", StatusCode::INTERNAL_SERVER_ERROR), | ||||||
| @@ -120,6 +121,11 @@ impl Code { | |||||||
|             // invalid ranking rule |             // invalid ranking rule | ||||||
|             InvalidRankingRule => ErrCode::invalid("invalid_request", StatusCode::BAD_REQUEST), |             InvalidRankingRule => ErrCode::invalid("invalid_request", StatusCode::BAD_REQUEST), | ||||||
|  |  | ||||||
|  |             // invalid database | ||||||
|  |             InvalidStore => { | ||||||
|  |                 ErrCode::internal("invalid_store_file", StatusCode::INTERNAL_SERVER_ERROR) | ||||||
|  |             } | ||||||
|  |  | ||||||
|             // invalid document |             // invalid document | ||||||
|             MaxFieldsLimitExceeded => { |             MaxFieldsLimitExceeded => { | ||||||
|                 ErrCode::invalid("max_fields_limit_exceeded", StatusCode::BAD_REQUEST) |                 ErrCode::invalid("max_fields_limit_exceeded", StatusCode::BAD_REQUEST) | ||||||
| @@ -136,17 +142,22 @@ impl Code { | |||||||
|  |  | ||||||
|             BadParameter => ErrCode::invalid("bad_parameter", StatusCode::BAD_REQUEST), |             BadParameter => ErrCode::invalid("bad_parameter", StatusCode::BAD_REQUEST), | ||||||
|             BadRequest => ErrCode::invalid("bad_request", StatusCode::BAD_REQUEST), |             BadRequest => ErrCode::invalid("bad_request", StatusCode::BAD_REQUEST), | ||||||
|  |             DatabaseSizeLimitReached => ErrCode::internal( | ||||||
|  |                 "database_size_limit_reached", | ||||||
|  |                 StatusCode::INTERNAL_SERVER_ERROR, | ||||||
|  |             ), | ||||||
|             DocumentNotFound => ErrCode::invalid("document_not_found", StatusCode::NOT_FOUND), |             DocumentNotFound => ErrCode::invalid("document_not_found", StatusCode::NOT_FOUND), | ||||||
|             Internal => ErrCode::internal("internal", StatusCode::INTERNAL_SERVER_ERROR), |             Internal => ErrCode::internal("internal", StatusCode::INTERNAL_SERVER_ERROR), | ||||||
|             InvalidGeoField => { |             InvalidGeoField => ErrCode::invalid("invalid_geo_field", StatusCode::BAD_REQUEST), | ||||||
|                 ErrCode::authentication("invalid_geo_field", StatusCode::BAD_REQUEST) |  | ||||||
|             } |  | ||||||
|             InvalidToken => ErrCode::authentication("invalid_api_key", StatusCode::FORBIDDEN), |             InvalidToken => ErrCode::authentication("invalid_api_key", StatusCode::FORBIDDEN), | ||||||
|             MissingAuthorizationHeader => { |             MissingAuthorizationHeader => { | ||||||
|                 ErrCode::authentication("missing_authorization_header", StatusCode::UNAUTHORIZED) |                 ErrCode::authentication("missing_authorization_header", StatusCode::UNAUTHORIZED) | ||||||
|             } |             } | ||||||
|             TaskNotFound => ErrCode::invalid("task_not_found", StatusCode::NOT_FOUND), |             TaskNotFound => ErrCode::invalid("task_not_found", StatusCode::NOT_FOUND), | ||||||
|             NotFound => ErrCode::invalid("not_found", StatusCode::NOT_FOUND), |             DumpNotFound => ErrCode::invalid("dump_not_found", StatusCode::NOT_FOUND), | ||||||
|  |             NoSpaceLeftOnDevice => { | ||||||
|  |                 ErrCode::internal("no_space_left_on_device", StatusCode::INTERNAL_SERVER_ERROR) | ||||||
|  |             } | ||||||
|             PayloadTooLarge => ErrCode::invalid("payload_too_large", StatusCode::PAYLOAD_TOO_LARGE), |             PayloadTooLarge => ErrCode::invalid("payload_too_large", StatusCode::PAYLOAD_TOO_LARGE), | ||||||
|             RetrieveDocument => { |             RetrieveDocument => { | ||||||
|                 ErrCode::internal("unretrievable_document", StatusCode::BAD_REQUEST) |                 ErrCode::internal("unretrievable_document", StatusCode::BAD_REQUEST) | ||||||
| @@ -158,7 +169,7 @@ impl Code { | |||||||
|  |  | ||||||
|             // error related to dump |             // error related to dump | ||||||
|             DumpAlreadyInProgress => { |             DumpAlreadyInProgress => { | ||||||
|                 ErrCode::invalid("dump_already_in_progress", StatusCode::CONFLICT) |                 ErrCode::invalid("dump_already_processing", StatusCode::CONFLICT) | ||||||
|             } |             } | ||||||
|             DumpProcessFailed => { |             DumpProcessFailed => { | ||||||
|                 ErrCode::internal("dump_process_failed", StatusCode::INTERNAL_SERVER_ERROR) |                 ErrCode::internal("dump_process_failed", StatusCode::INTERNAL_SERVER_ERROR) | ||||||
|   | |||||||
| @@ -2,14 +2,14 @@ use meilisearch_error::{Code, ErrorCode}; | |||||||
|  |  | ||||||
| #[derive(Debug, thiserror::Error)] | #[derive(Debug, thiserror::Error)] | ||||||
| pub enum AuthenticationError { | pub enum AuthenticationError { | ||||||
|     #[error("You must have an authorization token")] |     #[error("The X-MEILI-API-KEY header is missing.")] | ||||||
|     MissingAuthorizationHeader, |     MissingAuthorizationHeader, | ||||||
|     #[error("Invalid API key")] |     #[error("The provided API key is invalid.")] | ||||||
|     InvalidToken(String), |     InvalidToken(String), | ||||||
|     // Triggered on configuration error. |     // Triggered on configuration error. | ||||||
|     #[error("Irretrievable state")] |     #[error("An internal error has occurred. `Irretrievable state`.")] | ||||||
|     IrretrievableState, |     IrretrievableState, | ||||||
|     #[error("Unknown authentication policy")] |     #[error("An internal error has occurred. `Unknown authentication policy`.")] | ||||||
|     UnknownPolicy, |     UnknownPolicy, | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -7,6 +7,7 @@ use actix_web::http::StatusCode; | |||||||
| use paste::paste; | use paste::paste; | ||||||
| use serde_json::{json, Value}; | use serde_json::{json, Value}; | ||||||
| use tokio::time::sleep; | use tokio::time::sleep; | ||||||
|  | use urlencoding::encode; | ||||||
|  |  | ||||||
| use super::service::Service; | use super::service::Service; | ||||||
|  |  | ||||||
| @@ -14,12 +15,12 @@ macro_rules! make_settings_test_routes { | |||||||
|     ($($name:ident),+) => { |     ($($name:ident),+) => { | ||||||
|         $(paste! { |         $(paste! { | ||||||
|             pub async fn [<update_$name>](&self, value: Value) -> (Value, StatusCode) { |             pub async fn [<update_$name>](&self, value: Value) -> (Value, StatusCode) { | ||||||
|                 let url = format!("/indexes/{}/settings/{}", self.uid, stringify!($name).replace("_", "-")); |                 let url = format!("/indexes/{}/settings/{}", encode(self.uid.as_ref()).to_string(), stringify!($name).replace("_", "-")); | ||||||
|                 self.service.post(url, value).await |                 self.service.post(url, value).await | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             pub async fn [<get_$name>](&self) -> (Value, StatusCode) { |             pub async fn [<get_$name>](&self) -> (Value, StatusCode) { | ||||||
|                 let url = format!("/indexes/{}/settings/{}", self.uid, stringify!($name).replace("_", "-")); |                 let url = format!("/indexes/{}/settings/{}", encode(self.uid.as_ref()).to_string(), stringify!($name).replace("_", "-")); | ||||||
|                 self.service.get(url).await |                 self.service.get(url).await | ||||||
|             } |             } | ||||||
|         })* |         })* | ||||||
| @@ -34,12 +35,15 @@ pub struct Index<'a> { | |||||||
| #[allow(dead_code)] | #[allow(dead_code)] | ||||||
| impl Index<'_> { | impl Index<'_> { | ||||||
|     pub async fn get(&self) -> (Value, StatusCode) { |     pub async fn get(&self) -> (Value, StatusCode) { | ||||||
|         let url = format!("/indexes/{}", self.uid); |         let url = format!("/indexes/{}", encode(self.uid.as_ref()).to_string()); | ||||||
|         self.service.get(url).await |         self.service.get(url).await | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub async fn load_test_set(&self) -> u64 { |     pub async fn load_test_set(&self) -> u64 { | ||||||
|         let url = format!("/indexes/{}/documents", self.uid); |         let url = format!( | ||||||
|  |             "/indexes/{}/documents", | ||||||
|  |             encode(self.uid.as_ref()).to_string() | ||||||
|  |         ); | ||||||
|         let (response, code) = self |         let (response, code) = self | ||||||
|             .service |             .service | ||||||
|             .post_str(url, include_str!("../assets/test_set.json")) |             .post_str(url, include_str!("../assets/test_set.json")) | ||||||
| @@ -62,13 +66,13 @@ impl Index<'_> { | |||||||
|         let body = json!({ |         let body = json!({ | ||||||
|             "primaryKey": primary_key, |             "primaryKey": primary_key, | ||||||
|         }); |         }); | ||||||
|         let url = format!("/indexes/{}", self.uid); |         let url = format!("/indexes/{}", encode(self.uid.as_ref()).to_string()); | ||||||
|  |  | ||||||
|         self.service.put(url, body).await |         self.service.put(url, body).await | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub async fn delete(&self) -> (Value, StatusCode) { |     pub async fn delete(&self) -> (Value, StatusCode) { | ||||||
|         let url = format!("/indexes/{}", self.uid); |         let url = format!("/indexes/{}", encode(self.uid.as_ref()).to_string()); | ||||||
|         self.service.delete(url).await |         self.service.delete(url).await | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -78,8 +82,15 @@ impl Index<'_> { | |||||||
|         primary_key: Option<&str>, |         primary_key: Option<&str>, | ||||||
|     ) -> (Value, StatusCode) { |     ) -> (Value, StatusCode) { | ||||||
|         let url = match primary_key { |         let url = match primary_key { | ||||||
|             Some(key) => format!("/indexes/{}/documents?primaryKey={}", self.uid, key), |             Some(key) => format!( | ||||||
|             None => format!("/indexes/{}/documents", self.uid), |                 "/indexes/{}/documents?primaryKey={}", | ||||||
|  |                 encode(self.uid.as_ref()).to_string(), | ||||||
|  |                 key | ||||||
|  |             ), | ||||||
|  |             None => format!( | ||||||
|  |                 "/indexes/{}/documents", | ||||||
|  |                 encode(self.uid.as_ref()).to_string() | ||||||
|  |             ), | ||||||
|         }; |         }; | ||||||
|         self.service.post(url, documents).await |         self.service.post(url, documents).await | ||||||
|     } |     } | ||||||
| @@ -90,15 +101,26 @@ impl Index<'_> { | |||||||
|         primary_key: Option<&str>, |         primary_key: Option<&str>, | ||||||
|     ) -> (Value, StatusCode) { |     ) -> (Value, StatusCode) { | ||||||
|         let url = match primary_key { |         let url = match primary_key { | ||||||
|             Some(key) => format!("/indexes/{}/documents?primaryKey={}", self.uid, key), |             Some(key) => format!( | ||||||
|             None => format!("/indexes/{}/documents", self.uid), |                 "/indexes/{}/documents?primaryKey={}", | ||||||
|  |                 encode(self.uid.as_ref()).to_string(), | ||||||
|  |                 key | ||||||
|  |             ), | ||||||
|  |             None => format!( | ||||||
|  |                 "/indexes/{}/documents", | ||||||
|  |                 encode(self.uid.as_ref()).to_string() | ||||||
|  |             ), | ||||||
|         }; |         }; | ||||||
|         self.service.put(url, documents).await |         self.service.put(url, documents).await | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub async fn wait_update_id(&self, update_id: u64) -> Value { |     pub async fn wait_update_id(&self, update_id: u64) -> Value { | ||||||
|         // try 10 times to get status, or panic to not wait forever |         // try 10 times to get status, or panic to not wait forever | ||||||
|         let url = format!("/indexes/{}/updates/{}", self.uid, update_id); |         let url = format!( | ||||||
|  |             "/indexes/{}/updates/{}", | ||||||
|  |             encode(self.uid.as_ref()).to_string(), | ||||||
|  |             update_id | ||||||
|  |         ); | ||||||
|         for _ in 0..10 { |         for _ in 0..10 { | ||||||
|             let (response, status_code) = self.service.get(&url).await; |             let (response, status_code) = self.service.get(&url).await; | ||||||
|             assert_eq!(status_code, 200, "response: {}", response); |             assert_eq!(status_code, 200, "response: {}", response); | ||||||
| @@ -113,12 +135,16 @@ impl Index<'_> { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub async fn get_update(&self, update_id: u64) -> (Value, StatusCode) { |     pub async fn get_update(&self, update_id: u64) -> (Value, StatusCode) { | ||||||
|         let url = format!("/indexes/{}/updates/{}", self.uid, update_id); |         let url = format!( | ||||||
|  |             "/indexes/{}/updates/{}", | ||||||
|  |             encode(self.uid.as_ref()).to_string(), | ||||||
|  |             update_id | ||||||
|  |         ); | ||||||
|         self.service.get(url).await |         self.service.get(url).await | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub async fn list_updates(&self) -> (Value, StatusCode) { |     pub async fn list_updates(&self) -> (Value, StatusCode) { | ||||||
|         let url = format!("/indexes/{}/updates", self.uid); |         let url = format!("/indexes/{}/updates", encode(self.uid.as_ref()).to_string()); | ||||||
|         self.service.get(url).await |         self.service.get(url).await | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -127,12 +153,19 @@ impl Index<'_> { | |||||||
|         id: u64, |         id: u64, | ||||||
|         _options: Option<GetDocumentOptions>, |         _options: Option<GetDocumentOptions>, | ||||||
|     ) -> (Value, StatusCode) { |     ) -> (Value, StatusCode) { | ||||||
|         let url = format!("/indexes/{}/documents/{}", self.uid, id); |         let url = format!( | ||||||
|  |             "/indexes/{}/documents/{}", | ||||||
|  |             encode(self.uid.as_ref()).to_string(), | ||||||
|  |             id | ||||||
|  |         ); | ||||||
|         self.service.get(url).await |         self.service.get(url).await | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub async fn get_all_documents(&self, options: GetAllDocumentsOptions) -> (Value, StatusCode) { |     pub async fn get_all_documents(&self, options: GetAllDocumentsOptions) -> (Value, StatusCode) { | ||||||
|         let mut url = format!("/indexes/{}/documents?", self.uid); |         let mut url = format!( | ||||||
|  |             "/indexes/{}/documents?", | ||||||
|  |             encode(self.uid.as_ref()).to_string() | ||||||
|  |         ); | ||||||
|         if let Some(limit) = options.limit { |         if let Some(limit) = options.limit { | ||||||
|             url.push_str(&format!("limit={}&", limit)); |             url.push_str(&format!("limit={}&", limit)); | ||||||
|         } |         } | ||||||
| @@ -152,39 +185,58 @@ impl Index<'_> { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub async fn delete_document(&self, id: u64) -> (Value, StatusCode) { |     pub async fn delete_document(&self, id: u64) -> (Value, StatusCode) { | ||||||
|         let url = format!("/indexes/{}/documents/{}", self.uid, id); |         let url = format!( | ||||||
|  |             "/indexes/{}/documents/{}", | ||||||
|  |             encode(self.uid.as_ref()).to_string(), | ||||||
|  |             id | ||||||
|  |         ); | ||||||
|         self.service.delete(url).await |         self.service.delete(url).await | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub async fn clear_all_documents(&self) -> (Value, StatusCode) { |     pub async fn clear_all_documents(&self) -> (Value, StatusCode) { | ||||||
|         let url = format!("/indexes/{}/documents", self.uid); |         let url = format!( | ||||||
|  |             "/indexes/{}/documents", | ||||||
|  |             encode(self.uid.as_ref()).to_string() | ||||||
|  |         ); | ||||||
|         self.service.delete(url).await |         self.service.delete(url).await | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub async fn delete_batch(&self, ids: Vec<u64>) -> (Value, StatusCode) { |     pub async fn delete_batch(&self, ids: Vec<u64>) -> (Value, StatusCode) { | ||||||
|         let url = format!("/indexes/{}/documents/delete-batch", self.uid); |         let url = format!( | ||||||
|  |             "/indexes/{}/documents/delete-batch", | ||||||
|  |             encode(self.uid.as_ref()).to_string() | ||||||
|  |         ); | ||||||
|         self.service |         self.service | ||||||
|             .post(url, serde_json::to_value(&ids).unwrap()) |             .post(url, serde_json::to_value(&ids).unwrap()) | ||||||
|             .await |             .await | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub async fn settings(&self) -> (Value, StatusCode) { |     pub async fn settings(&self) -> (Value, StatusCode) { | ||||||
|         let url = format!("/indexes/{}/settings", self.uid); |         let url = format!( | ||||||
|  |             "/indexes/{}/settings", | ||||||
|  |             encode(self.uid.as_ref()).to_string() | ||||||
|  |         ); | ||||||
|         self.service.get(url).await |         self.service.get(url).await | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub async fn update_settings(&self, settings: Value) -> (Value, StatusCode) { |     pub async fn update_settings(&self, settings: Value) -> (Value, StatusCode) { | ||||||
|         let url = format!("/indexes/{}/settings", self.uid); |         let url = format!( | ||||||
|  |             "/indexes/{}/settings", | ||||||
|  |             encode(self.uid.as_ref()).to_string() | ||||||
|  |         ); | ||||||
|         self.service.post(url, settings).await |         self.service.post(url, settings).await | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub async fn delete_settings(&self) -> (Value, StatusCode) { |     pub async fn delete_settings(&self) -> (Value, StatusCode) { | ||||||
|         let url = format!("/indexes/{}/settings", self.uid); |         let url = format!( | ||||||
|  |             "/indexes/{}/settings", | ||||||
|  |             encode(self.uid.as_ref()).to_string() | ||||||
|  |         ); | ||||||
|         self.service.delete(url).await |         self.service.delete(url).await | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub async fn stats(&self) -> (Value, StatusCode) { |     pub async fn stats(&self) -> (Value, StatusCode) { | ||||||
|         let url = format!("/indexes/{}/stats", self.uid); |         let url = format!("/indexes/{}/stats", encode(self.uid.as_ref()).to_string()); | ||||||
|         self.service.get(url).await |         self.service.get(url).await | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -209,13 +261,17 @@ impl Index<'_> { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub async fn search_post(&self, query: Value) -> (Value, StatusCode) { |     pub async fn search_post(&self, query: Value) -> (Value, StatusCode) { | ||||||
|         let url = format!("/indexes/{}/search", self.uid); |         let url = format!("/indexes/{}/search", encode(self.uid.as_ref()).to_string()); | ||||||
|         self.service.post(url, query).await |         self.service.post(url, query).await | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     pub async fn search_get(&self, query: Value) -> (Value, StatusCode) { |     pub async fn search_get(&self, query: Value) -> (Value, StatusCode) { | ||||||
|         let params = serde_url_params::to_string(&query).unwrap(); |         let params = serde_url_params::to_string(&query).unwrap(); | ||||||
|         let url = format!("/indexes/{}/search?{}", self.uid, params); |         let url = format!( | ||||||
|  |             "/indexes/{}/search?{}", | ||||||
|  |             encode(self.uid.as_ref()).to_string(), | ||||||
|  |             params | ||||||
|  |         ); | ||||||
|         self.service.get(url).await |         self.service.get(url).await | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -7,7 +7,6 @@ use meilisearch_lib::options::{IndexerOpts, MaxMemory}; | |||||||
| use once_cell::sync::Lazy; | use once_cell::sync::Lazy; | ||||||
| use serde_json::Value; | use serde_json::Value; | ||||||
| use tempfile::TempDir; | use tempfile::TempDir; | ||||||
| use urlencoding::encode; |  | ||||||
|  |  | ||||||
| use meilisearch_http::option::Opt; | use meilisearch_http::option::Opt; | ||||||
|  |  | ||||||
| @@ -62,7 +61,7 @@ impl Server { | |||||||
|     /// Returns a view to an index. There is no guarantee that the index exists. |     /// Returns a view to an index. There is no guarantee that the index exists. | ||||||
|     pub fn index(&self, uid: impl AsRef<str>) -> Index<'_> { |     pub fn index(&self, uid: impl AsRef<str>) -> Index<'_> { | ||||||
|         Index { |         Index { | ||||||
|             uid: encode(uid.as_ref()).to_string(), |             uid: uid.as_ref().to_string(), | ||||||
|             service: &self.service, |             service: &self.service, | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -940,25 +940,29 @@ async fn error_document_field_limit_reached() { | |||||||
| } | } | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
| #[ignore] // // TODO: Fix in an other PR: this does not provoke any error. |  | ||||||
| async fn error_add_documents_invalid_geo_field() { | async fn error_add_documents_invalid_geo_field() { | ||||||
|     let server = Server::new().await; |     let server = Server::new().await; | ||||||
|     let index = server.index("test"); |     let index = server.index("test"); | ||||||
|     index.create(Some("id")).await; |     index.create(Some("id")).await; | ||||||
|  |     index | ||||||
|  |         .update_settings(json!({"sortableAttributes": ["_geo"]})) | ||||||
|  |         .await; | ||||||
|  |  | ||||||
|     let documents = json!([ |     let documents = json!([ | ||||||
|         { |         { | ||||||
|             "id": "11", |             "id": "11", | ||||||
|             "_geo": "foobar" |             "_geo": "foobar" | ||||||
|         } |         } | ||||||
|     ]); |     ]); | ||||||
|  |  | ||||||
|     index.add_documents(documents, None).await; |     index.add_documents(documents, None).await; | ||||||
|     index.wait_update_id(0).await; |     index.wait_update_id(1).await; | ||||||
|     let (response, code) = index.get_update(0).await; |     let (response, code) = index.get_update(1).await; | ||||||
|     assert_eq!(code, 200); |     assert_eq!(code, 200); | ||||||
|     assert_eq!(response["status"], "failed"); |     assert_eq!(response["status"], "failed"); | ||||||
|     assert_eq!( |     assert_eq!( | ||||||
|         response["message"], |         response["message"], | ||||||
|         r#"The document with the id: `11` contains an invalid _geo field: :syntaxErrorHelper:REPLACE_ME."# |         r#"The document with the id: `11` contains an invalid _geo field: `foobar`."# | ||||||
|     ); |     ); | ||||||
|     assert_eq!(response["code"], "invalid_geo_field"); |     assert_eq!(response["code"], "invalid_geo_field"); | ||||||
|     assert_eq!(response["type"], "invalid_request"); |     assert_eq!(response["type"], "invalid_request"); | ||||||
|   | |||||||
| @@ -89,7 +89,6 @@ async fn error_create_existing_index() { | |||||||
| } | } | ||||||
|  |  | ||||||
| #[actix_rt::test] | #[actix_rt::test] | ||||||
| #[ignore] // TODO: Fix in an other PR: uid returned `test%20test%23%21` instead of `test test#!` |  | ||||||
| async fn error_create_with_invalid_index_uid() { | async fn error_create_with_invalid_index_uid() { | ||||||
|     let server = Server::new().await; |     let server = Server::new().await; | ||||||
|     let index = server.index("test test#!"); |     let index = server.index("test test#!"); | ||||||
|   | |||||||
| @@ -25,7 +25,7 @@ impl fmt::Display for PayloadType { | |||||||
|  |  | ||||||
| #[derive(thiserror::Error, Debug)] | #[derive(thiserror::Error, Debug)] | ||||||
| pub enum DocumentFormatError { | pub enum DocumentFormatError { | ||||||
|     #[error("Internal error!: {0}")] |     #[error("An internal error has occurred. `{0}`.")] | ||||||
|     Internal(Box<dyn std::error::Error + Send + Sync + 'static>), |     Internal(Box<dyn std::error::Error + Send + Sync + 'static>), | ||||||
|     #[error("The `{1}` payload provided is malformed. `{0}`.")] |     #[error("The `{1}` payload provided is malformed. `{0}`.")] | ||||||
|     MalformedPayload( |     MalformedPayload( | ||||||
|   | |||||||
| @@ -36,11 +36,11 @@ impl ErrorCode for MilliError<'_> { | |||||||
|                 match error { |                 match error { | ||||||
|                     // TODO: wait for spec for new error codes. |                     // TODO: wait for spec for new error codes. | ||||||
|                     UserError::SerdeJson(_) |                     UserError::SerdeJson(_) | ||||||
|                     | UserError::MaxDatabaseSizeReached |  | ||||||
|                     | UserError::InvalidStoreFile |  | ||||||
|                     | UserError::NoSpaceLeftOnDevice |  | ||||||
|                     | UserError::DocumentLimitReached |                     | UserError::DocumentLimitReached | ||||||
|                     | UserError::UnknownInternalDocumentId { .. } => Code::Internal, |                     | UserError::UnknownInternalDocumentId { .. } => Code::Internal, | ||||||
|  |                     UserError::InvalidStoreFile => Code::InvalidStore, | ||||||
|  |                     UserError::NoSpaceLeftOnDevice => Code::NoSpaceLeftOnDevice, | ||||||
|  |                     UserError::MaxDatabaseSizeReached => Code::DatabaseSizeLimitReached, | ||||||
|                     UserError::AttributeLimitReached => Code::MaxFieldsLimitExceeded, |                     UserError::AttributeLimitReached => Code::MaxFieldsLimitExceeded, | ||||||
|                     UserError::InvalidFilter(_) => Code::Filter, |                     UserError::InvalidFilter(_) => Code::Filter, | ||||||
|                     UserError::MissingDocumentId { .. } => Code::MissingDocumentId, |                     UserError::MissingDocumentId { .. } => Code::MissingDocumentId, | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ pub type Result<T> = std::result::Result<T, IndexError>; | |||||||
|  |  | ||||||
| #[derive(Debug, thiserror::Error)] | #[derive(Debug, thiserror::Error)] | ||||||
| pub enum IndexError { | pub enum IndexError { | ||||||
|     #[error("Internal error: {0}")] |     #[error("An internal error has occurred. `{0}`.")] | ||||||
|     Internal(Box<dyn Error + Send + Sync + 'static>), |     Internal(Box<dyn Error + Send + Sync + 'static>), | ||||||
|     #[error("Document `{0}` not found.")] |     #[error("Document `{0}` not found.")] | ||||||
|     DocumentNotFound(String), |     DocumentNotFound(String), | ||||||
|   | |||||||
| @@ -7,11 +7,11 @@ pub type Result<T> = std::result::Result<T, DumpActorError>; | |||||||
|  |  | ||||||
| #[derive(thiserror::Error, Debug)] | #[derive(thiserror::Error, Debug)] | ||||||
| pub enum DumpActorError { | pub enum DumpActorError { | ||||||
|     #[error("Another dump is already in progress")] |     #[error("A dump is already processing. You must wait until the current process is finished before requesting another dump.")] | ||||||
|     DumpAlreadyRunning, |     DumpAlreadyRunning, | ||||||
|     #[error("Dump `{0}` not found.")] |     #[error("Dump `{0}` not found.")] | ||||||
|     DumpDoesNotExist(String), |     DumpDoesNotExist(String), | ||||||
|     #[error("Internal error: {0}")] |     #[error("An internal error has occurred. `{0}`.")] | ||||||
|     Internal(Box<dyn std::error::Error + Send + Sync + 'static>), |     Internal(Box<dyn std::error::Error + Send + Sync + 'static>), | ||||||
|     #[error("{0}")] |     #[error("{0}")] | ||||||
|     IndexResolver(#[from] IndexResolverError), |     IndexResolver(#[from] IndexResolverError), | ||||||
| @@ -43,7 +43,7 @@ impl ErrorCode for DumpActorError { | |||||||
|     fn error_code(&self) -> Code { |     fn error_code(&self) -> Code { | ||||||
|         match self { |         match self { | ||||||
|             DumpActorError::DumpAlreadyRunning => Code::DumpAlreadyInProgress, |             DumpActorError::DumpAlreadyRunning => Code::DumpAlreadyInProgress, | ||||||
|             DumpActorError::DumpDoesNotExist(_) => Code::NotFound, |             DumpActorError::DumpDoesNotExist(_) => Code::DumpNotFound, | ||||||
|             DumpActorError::Internal(_) => Code::Internal, |             DumpActorError::Internal(_) => Code::Internal, | ||||||
|             DumpActorError::IndexResolver(e) => e.error_code(), |             DumpActorError::IndexResolver(e) => e.error_code(), | ||||||
|             DumpActorError::UpdateLoop(e) => e.error_code(), |             DumpActorError::UpdateLoop(e) => e.error_code(), | ||||||
|   | |||||||
| @@ -361,7 +361,6 @@ mod compat { | |||||||
|             "index_already_exists" => Code::IndexAlreadyExists, |             "index_already_exists" => Code::IndexAlreadyExists, | ||||||
|             "index_not_found" => Code::IndexNotFound, |             "index_not_found" => Code::IndexNotFound, | ||||||
|             "invalid_index_uid" => Code::InvalidIndexUid, |             "invalid_index_uid" => Code::InvalidIndexUid, | ||||||
|             "index_not_accessible" => Code::OpenIndex, |  | ||||||
|             "invalid_state" => Code::InvalidState, |             "invalid_state" => Code::InvalidState, | ||||||
|             "missing_primary_key" => Code::MissingPrimaryKey, |             "missing_primary_key" => Code::MissingPrimaryKey, | ||||||
|             "primary_key_already_present" => Code::PrimaryKeyAlreadyPresent, |             "primary_key_already_present" => Code::PrimaryKeyAlreadyPresent, | ||||||
| @@ -378,7 +377,6 @@ mod compat { | |||||||
|             "invalid_geo_field" => Code::InvalidGeoField, |             "invalid_geo_field" => Code::InvalidGeoField, | ||||||
|             "invalid_token" => Code::InvalidToken, |             "invalid_token" => Code::InvalidToken, | ||||||
|             "missing_authorization_header" => Code::MissingAuthorizationHeader, |             "missing_authorization_header" => Code::MissingAuthorizationHeader, | ||||||
|             "not_found" => Code::NotFound, |  | ||||||
|             "payload_too_large" => Code::PayloadTooLarge, |             "payload_too_large" => Code::PayloadTooLarge, | ||||||
|             "unretrievable_document" => Code::RetrieveDocument, |             "unretrievable_document" => Code::RetrieveDocument, | ||||||
|             "search_error" => Code::SearchDocuments, |             "search_error" => Code::SearchDocuments, | ||||||
|   | |||||||
| @@ -24,7 +24,7 @@ pub enum IndexControllerError { | |||||||
|     DumpActor(#[from] DumpActorError), |     DumpActor(#[from] DumpActorError), | ||||||
|     #[error("{0}")] |     #[error("{0}")] | ||||||
|     IndexError(#[from] IndexError), |     IndexError(#[from] IndexError), | ||||||
|     #[error("Internal error: {0}")] |     #[error("An internal error has occurred. `{0}`.")] | ||||||
|     Internal(Box<dyn Error + Send + Sync + 'static>), |     Internal(Box<dyn Error + Send + Sync + 'static>), | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -19,9 +19,9 @@ pub enum IndexResolverError { | |||||||
|     UnexistingIndex(String), |     UnexistingIndex(String), | ||||||
|     #[error("A primary key is already present. It's impossible to update it")] |     #[error("A primary key is already present. It's impossible to update it")] | ||||||
|     ExistingPrimaryKey, |     ExistingPrimaryKey, | ||||||
|     #[error("Internal Error: `{0}`")] |     #[error("An internal error has occurred. `{0}`.")] | ||||||
|     Internal(Box<dyn std::error::Error + Send + Sync + 'static>), |     Internal(Box<dyn std::error::Error + Send + Sync + 'static>), | ||||||
|     #[error("Internal Error: Index uuid `{0}` is already assigned.")] |     #[error("The creation of the `{0}` index has failed due to `Index uuid is already assigned`.")] | ||||||
|     UuidAlreadyExists(Uuid), |     UuidAlreadyExists(Uuid), | ||||||
|     #[error("{0}")] |     #[error("{0}")] | ||||||
|     Milli(#[from] milli::Error), |     Milli(#[from] milli::Error), | ||||||
| @@ -60,7 +60,7 @@ impl ErrorCode for IndexResolverError { | |||||||
|             IndexResolverError::UnexistingIndex(_) => Code::IndexNotFound, |             IndexResolverError::UnexistingIndex(_) => Code::IndexNotFound, | ||||||
|             IndexResolverError::ExistingPrimaryKey => Code::PrimaryKeyAlreadyPresent, |             IndexResolverError::ExistingPrimaryKey => Code::PrimaryKeyAlreadyPresent, | ||||||
|             IndexResolverError::Internal(_) => Code::Internal, |             IndexResolverError::Internal(_) => Code::Internal, | ||||||
|             IndexResolverError::UuidAlreadyExists(_) => Code::Internal, |             IndexResolverError::UuidAlreadyExists(_) => Code::CreateIndex, | ||||||
|             IndexResolverError::Milli(e) => MilliError(e).error_code(), |             IndexResolverError::Milli(e) => MilliError(e).error_code(), | ||||||
|             IndexResolverError::BadlyFormatted(_) => Code::InvalidIndexUid, |             IndexResolverError::BadlyFormatted(_) => Code::InvalidIndexUid, | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -16,7 +16,7 @@ pub type Result<T> = std::result::Result<T, UpdateLoopError>; | |||||||
| pub enum UpdateLoopError { | pub enum UpdateLoopError { | ||||||
|     #[error("Task `{0}` not found.")] |     #[error("Task `{0}` not found.")] | ||||||
|     UnexistingUpdate(u64), |     UnexistingUpdate(u64), | ||||||
|     #[error("Internal error: {0}")] |     #[error("An internal error has occurred. `{0}`.")] | ||||||
|     Internal(Box<dyn Error + Send + Sync + 'static>), |     Internal(Box<dyn Error + Send + Sync + 'static>), | ||||||
|     #[error( |     #[error( | ||||||
|         "update store was shut down due to a fatal error, please check your logs for more info." |         "update store was shut down due to a fatal error, please check your logs for more info." | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user