mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 13:06:27 +00:00 
			
		
		
		
	Merge #4716
4716: Fix bad http status and error message on wrong payload r=irevoire a=Karribalu # Pull Request ## Related issue Fixes #4698 ## What does this PR do? - Fixes bad http status when bad payload with gzip Content-Encoding ## PR checklist Please check if your PR fulfills the following requirements: - [x] Does this PR fix an existing issue, or have you listed the changes applied in the PR description (and why they are needed)? - [x] Have you read the contributing guidelines? - [x] Have you made sure that the title is accurate and descriptive of the changes? Thank you so much for contributing to Meilisearch! Co-authored-by: karribalu <karri.balu123456@gmail.com>
This commit is contained in:
		| @@ -98,14 +98,29 @@ impl From<MeilisearchHttpError> for aweb::Error { | ||||
|  | ||||
| impl From<aweb::error::PayloadError> for MeilisearchHttpError { | ||||
|     fn from(error: aweb::error::PayloadError) -> Self { | ||||
|         MeilisearchHttpError::Payload(PayloadError::Payload(error)) | ||||
|         match error { | ||||
|             aweb::error::PayloadError::Incomplete(_) => MeilisearchHttpError::Payload( | ||||
|                 PayloadError::Payload(ActixPayloadError::IncompleteError), | ||||
|             ), | ||||
|             _ => MeilisearchHttpError::Payload(PayloadError::Payload( | ||||
|                 ActixPayloadError::OtherError(error), | ||||
|             )), | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| #[derive(Debug, thiserror::Error)] | ||||
| pub enum ActixPayloadError { | ||||
|     #[error("The provided payload is incomplete and cannot be parsed")] | ||||
|     IncompleteError, | ||||
|     #[error(transparent)] | ||||
|     OtherError(aweb::error::PayloadError), | ||||
| } | ||||
|  | ||||
| #[derive(Debug, thiserror::Error)] | ||||
| pub enum PayloadError { | ||||
|     #[error(transparent)] | ||||
|     Payload(aweb::error::PayloadError), | ||||
|     Payload(ActixPayloadError), | ||||
|     #[error(transparent)] | ||||
|     Json(JsonPayloadError), | ||||
|     #[error(transparent)] | ||||
| @@ -122,7 +137,8 @@ impl ErrorCode for PayloadError { | ||||
|     fn error_code(&self) -> Code { | ||||
|         match self { | ||||
|             PayloadError::Payload(e) => match e { | ||||
|                 aweb::error::PayloadError::Incomplete(_) => Code::Internal, | ||||
|                 ActixPayloadError::IncompleteError => Code::BadRequest, | ||||
|                 ActixPayloadError::OtherError(error) => match error { | ||||
|                     aweb::error::PayloadError::EncodingCorrupted => Code::Internal, | ||||
|                     aweb::error::PayloadError::Overflow => Code::PayloadTooLarge, | ||||
|                     aweb::error::PayloadError::UnknownLength => Code::Internal, | ||||
| @@ -130,6 +146,7 @@ impl ErrorCode for PayloadError { | ||||
|                     aweb::error::PayloadError::Io(_) => Code::Internal, | ||||
|                     _ => todo!(), | ||||
|                 }, | ||||
|             }, | ||||
|             PayloadError::Json(err) => match err { | ||||
|                 JsonPayloadError::Overflow { .. } => Code::PayloadTooLarge, | ||||
|                 JsonPayloadError::ContentType => Code::UnsupportedMediaType, | ||||
|   | ||||
| @@ -183,6 +183,58 @@ async fn add_single_document_gzip_encoded() { | ||||
|     } | ||||
|     "###); | ||||
| } | ||||
| #[actix_rt::test] | ||||
| async fn add_single_document_gzip_encoded_with_incomplete_error() { | ||||
|     let document = json!("kefir"); | ||||
|  | ||||
|     // this is a what is expected and should work | ||||
|     let server = Server::new().await; | ||||
|     let app = server.init_web_app().await; | ||||
|     // post | ||||
|     let document = serde_json::to_string(&document).unwrap(); | ||||
|     let req = test::TestRequest::post() | ||||
|         .uri("/indexes/dog/documents") | ||||
|         .set_payload(document.to_string()) | ||||
|         .insert_header(("content-type", "application/json")) | ||||
|         .insert_header(("content-encoding", "gzip")) | ||||
|         .to_request(); | ||||
|     let res = test::call_service(&app, req).await; | ||||
|     let status_code = res.status(); | ||||
|     let body = test::read_body(res).await; | ||||
|     let response: Value = serde_json::from_slice(&body).unwrap_or_default(); | ||||
|     snapshot!(status_code, @"400 Bad Request"); | ||||
|     snapshot!(json_string!(response), | ||||
|         @r###" | ||||
|     { | ||||
|       "message": "The provided payload is incomplete and cannot be parsed", | ||||
|       "code": "bad_request", | ||||
|       "type": "invalid_request", | ||||
|       "link": "https://docs.meilisearch.com/errors#bad_request" | ||||
|     } | ||||
|     "###); | ||||
|  | ||||
|     // put | ||||
|     let req = test::TestRequest::put() | ||||
|         .uri("/indexes/dog/documents") | ||||
|         .set_payload(document.to_string()) | ||||
|         .insert_header(("content-type", "application/json")) | ||||
|         .insert_header(("content-encoding", "gzip")) | ||||
|         .to_request(); | ||||
|     let res = test::call_service(&app, req).await; | ||||
|     let status_code = res.status(); | ||||
|     let body = test::read_body(res).await; | ||||
|     let response: Value = serde_json::from_slice(&body).unwrap_or_default(); | ||||
|     snapshot!(status_code, @"400 Bad Request"); | ||||
|     snapshot!(json_string!(response), | ||||
|         @r###" | ||||
|     { | ||||
|       "message": "The provided payload is incomplete and cannot be parsed", | ||||
|       "code": "bad_request", | ||||
|       "type": "invalid_request", | ||||
|       "link": "https://docs.meilisearch.com/errors#bad_request" | ||||
|     } | ||||
|     "###); | ||||
| } | ||||
|  | ||||
| /// Here we try document request with every encoding | ||||
| #[actix_rt::test] | ||||
|   | ||||
		Reference in New Issue
	
	Block a user