mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-26 13:36:27 +00:00 
			
		
		
		
	Merge branch 'main' into fix-3037
This commit is contained in:
		| @@ -352,7 +352,7 @@ async fn error_add_api_key_invalid_parameters_indexes() { | ||||
|     assert_eq!(400, code, "{:?}", &response); | ||||
|  | ||||
|     let expected_response = json!({ | ||||
|         "message": r#"`{"name":"products"}` is not a valid index uid. It should be an array of string representing index names."#, | ||||
|         "message": r#"`indexes` field value `{"name":"products"}` is invalid. It should be an array of string representing index names."#, | ||||
|         "code": "invalid_api_key_indexes", | ||||
|         "type": "invalid_request", | ||||
|         "link": "https://docs.meilisearch.com/errors#invalid_api_key_indexes" | ||||
| @@ -377,7 +377,7 @@ async fn error_add_api_key_invalid_index_uids() { | ||||
|     let (response, code) = server.add_api_key(content).await; | ||||
|  | ||||
|     let expected_response = json!({ | ||||
|         "message": r#"`["invalid index # / \\name with spaces"]` is not a valid index uid. It should be an array of string representing index names."#, | ||||
|         "message": r#"`invalid index # / \name with spaces` is not a valid index uid. Index uid can be an integer or a string containing only alphanumeric characters, hyphens (-) and underscores (_)."#, | ||||
|         "code": "invalid_api_key_indexes", | ||||
|         "type": "invalid_request", | ||||
|         "link": "https://docs.meilisearch.com/errors#invalid_api_key_indexes" | ||||
| @@ -1434,12 +1434,13 @@ async fn error_access_api_key_routes_no_master_key_set() { | ||||
|  | ||||
|     server.use_api_key("MASTER_KEY"); | ||||
|  | ||||
|     let expected_response = json!({"message": "The provided API key is invalid.", | ||||
|         "code": "invalid_api_key", | ||||
|     let expected_response = json!({ | ||||
|         "message": "Meilisearch is running without a master key. To access this API endpoint, you must have set a master key at launch.", | ||||
|         "code": "missing_master_key", | ||||
|         "type": "auth", | ||||
|         "link": "https://docs.meilisearch.com/errors#invalid_api_key" | ||||
|         "link": "https://docs.meilisearch.com/errors#missing_master_key" | ||||
|     }); | ||||
|     let expected_code = 403; | ||||
|     let expected_code = 401; | ||||
|  | ||||
|     let (response, code) = server.add_api_key(json!({})).await; | ||||
|  | ||||
|   | ||||
| @@ -106,17 +106,17 @@ impl Index<'_> { | ||||
|     } | ||||
|  | ||||
|     pub async fn list_tasks(&self) -> (Value, StatusCode) { | ||||
|         let url = format!("/tasks?indexUid={}", self.uid); | ||||
|         let url = format!("/tasks?indexUids={}", self.uid); | ||||
|         self.service.get(url).await | ||||
|     } | ||||
|  | ||||
|     pub async fn filtered_tasks(&self, type_: &[&str], status: &[&str]) -> (Value, StatusCode) { | ||||
|         let mut url = format!("/tasks?indexUid={}", self.uid); | ||||
|         if !type_.is_empty() { | ||||
|             let _ = write!(url, "&type={}", type_.join(",")); | ||||
|     pub async fn filtered_tasks(&self, types: &[&str], statuses: &[&str]) -> (Value, StatusCode) { | ||||
|         let mut url = format!("/tasks?indexUids={}", self.uid); | ||||
|         if !types.is_empty() { | ||||
|             let _ = write!(url, "&types={}", types.join(",")); | ||||
|         } | ||||
|         if !status.is_empty() { | ||||
|             let _ = write!(url, "&status={}", status.join(",")); | ||||
|         if !statuses.is_empty() { | ||||
|             let _ = write!(url, "&statuses={}", statuses.join(",")); | ||||
|         } | ||||
|         self.service.get(url).await | ||||
|     } | ||||
|   | ||||
| @@ -132,6 +132,10 @@ impl Server { | ||||
|         self.service.get("/tasks").await | ||||
|     } | ||||
|  | ||||
|     pub async fn tasks_filter(&self, filter: Value) -> (Value, StatusCode) { | ||||
|         self.service.get(format!("/tasks?{}", yaup::to_string(&filter).unwrap())).await | ||||
|     } | ||||
|  | ||||
|     pub async fn get_dump_status(&self, uid: &str) -> (Value, StatusCode) { | ||||
|         self.service.get(format!("/dumps/{}/status", uid)).await | ||||
|     } | ||||
| @@ -144,13 +148,13 @@ impl Server { | ||||
|         self.service.post("/swap-indexes", value).await | ||||
|     } | ||||
|  | ||||
|     pub async fn cancel_task(&self, value: Value) -> (Value, StatusCode) { | ||||
|     pub async fn cancel_tasks(&self, value: Value) -> (Value, StatusCode) { | ||||
|         self.service | ||||
|             .post(format!("/tasks/cancel?{}", yaup::to_string(&value).unwrap()), json!(null)) | ||||
|             .await | ||||
|     } | ||||
|  | ||||
|     pub async fn delete_task(&self, value: Value) -> (Value, StatusCode) { | ||||
|     pub async fn delete_tasks(&self, value: Value) -> (Value, StatusCode) { | ||||
|         self.service.delete(format!("/tasks?{}", yaup::to_string(&value).unwrap())).await | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -636,7 +636,7 @@ async fn error_document_add_create_index_bad_uid() { | ||||
|     let (response, code) = index.add_documents(json!([{"id": 1}]), None).await; | ||||
|  | ||||
|     let expected_response = json!({ | ||||
|         "message": "invalid index uid `883  fj!`, the uid must be an integer or a string containing only alphanumeric characters a-z A-Z 0-9, hyphens - and underscores _.", | ||||
|         "message": "`883  fj!` is not a valid index uid. Index uid can be an integer or a string containing only alphanumeric characters, hyphens (-) and underscores (_).", | ||||
|         "code": "invalid_index_uid", | ||||
|         "type": "invalid_request", | ||||
|         "link": "https://docs.meilisearch.com/errors#invalid_index_uid" | ||||
|   | ||||
| @@ -10,7 +10,7 @@ async fn error_document_update_create_index_bad_uid() { | ||||
|     let (response, code) = index.update_documents(json!([{"id": 1}]), None).await; | ||||
|  | ||||
|     let expected_response = json!({ | ||||
|         "message": "invalid index uid `883  fj!`, the uid must be an integer or a string containing only alphanumeric characters a-z A-Z 0-9, hyphens - and underscores _.", | ||||
|         "message": "`883  fj!` is not a valid index uid. Index uid can be an integer or a string containing only alphanumeric characters, hyphens (-) and underscores (_).", | ||||
|         "code": "invalid_index_uid", | ||||
|         "type": "invalid_request", | ||||
|         "link": "https://docs.meilisearch.com/errors#invalid_index_uid" | ||||
|   | ||||
| @@ -59,7 +59,7 @@ async fn import_dump_v2_movie_raw() { | ||||
|     assert_eq!(code, 200); | ||||
|     assert_eq!( | ||||
|         tasks, | ||||
|         json!({ "results": [{"uid": 0, "indexUid": "indexUID", "status": "succeeded", "type": "documentAdditionOrUpdate", "details": { "receivedDocuments": 0, "indexedDocuments": 31944 }, "duration": "PT41.751156S", "enqueuedAt": "2021-09-08T08:30:30.550282Z", "startedAt": "2021-09-08T08:30:30.553012Z", "finishedAt": "2021-09-08T08:31:12.304168Z" }], "limit": 20, "from": 0, "next": null }) | ||||
|         json!({ "results": [{"uid": 0, "indexUid": "indexUID", "status": "succeeded", "type": "documentAdditionOrUpdate", "canceledBy": null, "details": { "receivedDocuments": 0, "indexedDocuments": 31944 }, "error": null, "duration": "PT41.751156S", "enqueuedAt": "2021-09-08T08:30:30.550282Z", "startedAt": "2021-09-08T08:30:30.553012Z", "finishedAt": "2021-09-08T08:31:12.304168Z" }], "limit": 20, "from": 0, "next": null }) | ||||
|     ); | ||||
|  | ||||
|     // finally we're just going to check that we can still get a few documents by id | ||||
| @@ -122,7 +122,7 @@ async fn import_dump_v2_movie_with_settings() { | ||||
|     assert_eq!(code, 200); | ||||
|     assert_eq!( | ||||
|         tasks, | ||||
|         json!({ "results": [{ "uid": 1, "indexUid": "indexUID", "status": "succeeded", "type": "settingsUpdate", "details": { "displayedAttributes": ["title", "genres", "overview", "poster", "release_date"], "searchableAttributes": ["title", "overview"], "filterableAttributes": ["genres"], "stopWords": ["of", "the"] }, "duration": "PT37.488777S", "enqueuedAt": "2021-09-08T08:24:02.323444Z", "startedAt": "2021-09-08T08:24:02.324145Z", "finishedAt": "2021-09-08T08:24:39.812922Z" }, { "uid": 0, "indexUid": "indexUID", "status": "succeeded", "type": "documentAdditionOrUpdate", "details": { "receivedDocuments": 0, "indexedDocuments": 31944 }, "duration": "PT39.941318S", "enqueuedAt": "2021-09-08T08:21:14.742672Z", "startedAt": "2021-09-08T08:21:14.750166Z", "finishedAt": "2021-09-08T08:21:54.691484Z" }], "limit": 20, "from": 1, "next": null }) | ||||
|         json!({ "results": [{ "uid": 1, "indexUid": "indexUID", "status": "succeeded", "type": "settingsUpdate", "canceledBy": null, "details": { "displayedAttributes": ["title", "genres", "overview", "poster", "release_date"], "searchableAttributes": ["title", "overview"], "filterableAttributes": ["genres"], "stopWords": ["of", "the"] }, "error": null, "duration": "PT37.488777S", "enqueuedAt": "2021-09-08T08:24:02.323444Z", "startedAt": "2021-09-08T08:24:02.324145Z", "finishedAt": "2021-09-08T08:24:39.812922Z" }, { "uid": 0, "indexUid": "indexUID", "status": "succeeded", "type": "documentAdditionOrUpdate", "canceledBy": null, "details": { "receivedDocuments": 0, "indexedDocuments": 31944 }, "error": null, "duration": "PT39.941318S", "enqueuedAt": "2021-09-08T08:21:14.742672Z", "startedAt": "2021-09-08T08:21:14.750166Z", "finishedAt": "2021-09-08T08:21:54.691484Z" }], "limit": 20, "from": 1, "next": null }) | ||||
|     ); | ||||
|  | ||||
|     // finally we're just going to check that we can still get a few documents by id | ||||
| @@ -185,7 +185,7 @@ async fn import_dump_v2_rubygems_with_settings() { | ||||
|     assert_eq!(code, 200); | ||||
|     assert_eq!( | ||||
|         tasks["results"][0], | ||||
|         json!({"uid": 92, "indexUid": "rubygems", "status": "succeeded", "type": "documentAdditionOrUpdate", "details": {"receivedDocuments": 0, "indexedDocuments": 1042}, "duration": "PT14.034672S", "enqueuedAt": "2021-09-08T08:40:31.390775Z", "startedAt": "2021-09-08T08:51:39.060642Z", "finishedAt": "2021-09-08T08:51:53.095314Z"}) | ||||
|         json!({"uid": 92, "indexUid": "rubygems", "status": "succeeded", "type": "documentAdditionOrUpdate", "canceledBy": null, "details": {"receivedDocuments": 0, "indexedDocuments": 1042}, "error": null, "duration": "PT14.034672S", "enqueuedAt": "2021-09-08T08:40:31.390775Z", "startedAt": "2021-09-08T08:51:39.060642Z", "finishedAt": "2021-09-08T08:51:53.095314Z"}) | ||||
|     ); | ||||
|  | ||||
|     // finally we're just going to check that we can still get a few documents by id | ||||
| @@ -246,7 +246,7 @@ async fn import_dump_v3_movie_raw() { | ||||
|     assert_eq!(code, 200); | ||||
|     assert_eq!( | ||||
|         tasks, | ||||
|         json!({ "results": [{"uid": 0, "indexUid": "indexUID", "status": "succeeded", "type": "documentAdditionOrUpdate", "details": { "receivedDocuments": 0, "indexedDocuments": 31944 }, "duration": "PT41.751156S", "enqueuedAt": "2021-09-08T08:30:30.550282Z", "startedAt": "2021-09-08T08:30:30.553012Z", "finishedAt": "2021-09-08T08:31:12.304168Z" }], "limit": 20, "from": 0, "next": null }) | ||||
|         json!({ "results": [{"uid": 0, "indexUid": "indexUID", "status": "succeeded", "type": "documentAdditionOrUpdate", "canceledBy": null, "details": { "receivedDocuments": 0, "indexedDocuments": 31944 }, "error": null, "duration": "PT41.751156S", "enqueuedAt": "2021-09-08T08:30:30.550282Z", "startedAt": "2021-09-08T08:30:30.553012Z", "finishedAt": "2021-09-08T08:31:12.304168Z" }], "limit": 20, "from": 0, "next": null }) | ||||
|     ); | ||||
|  | ||||
|     // finally we're just going to check that we can still get a few documents by id | ||||
| @@ -309,7 +309,7 @@ async fn import_dump_v3_movie_with_settings() { | ||||
|     assert_eq!(code, 200); | ||||
|     assert_eq!( | ||||
|         tasks, | ||||
|         json!({ "results": [{ "uid": 1, "indexUid": "indexUID", "status": "succeeded", "type": "settingsUpdate", "details": { "displayedAttributes": ["title", "genres", "overview", "poster", "release_date"], "searchableAttributes": ["title", "overview"], "filterableAttributes": ["genres"], "stopWords": ["of", "the"] }, "duration": "PT37.488777S", "enqueuedAt": "2021-09-08T08:24:02.323444Z", "startedAt": "2021-09-08T08:24:02.324145Z", "finishedAt": "2021-09-08T08:24:39.812922Z" }, { "uid": 0, "indexUid": "indexUID", "status": "succeeded", "type": "documentAdditionOrUpdate", "details": { "receivedDocuments": 0, "indexedDocuments": 31944 }, "duration": "PT39.941318S", "enqueuedAt": "2021-09-08T08:21:14.742672Z", "startedAt": "2021-09-08T08:21:14.750166Z", "finishedAt": "2021-09-08T08:21:54.691484Z" }], "limit": 20, "from": 1, "next": null }) | ||||
|         json!({ "results": [{ "uid": 1, "indexUid": "indexUID", "status": "succeeded", "type": "settingsUpdate", "canceledBy": null, "details": { "displayedAttributes": ["title", "genres", "overview", "poster", "release_date"], "searchableAttributes": ["title", "overview"], "filterableAttributes": ["genres"], "stopWords": ["of", "the"] }, "error": null, "duration": "PT37.488777S", "enqueuedAt": "2021-09-08T08:24:02.323444Z", "startedAt": "2021-09-08T08:24:02.324145Z", "finishedAt": "2021-09-08T08:24:39.812922Z" }, { "uid": 0, "indexUid": "indexUID", "status": "succeeded", "type": "documentAdditionOrUpdate", "canceledBy": null, "details": { "receivedDocuments": 0, "indexedDocuments": 31944 }, "error": null, "duration": "PT39.941318S", "enqueuedAt": "2021-09-08T08:21:14.742672Z", "startedAt": "2021-09-08T08:21:14.750166Z", "finishedAt": "2021-09-08T08:21:54.691484Z" }], "limit": 20, "from": 1, "next": null }) | ||||
|     ); | ||||
|  | ||||
|     // finally we're just going to check that we can["results"] still get a few documents by id | ||||
| @@ -372,7 +372,7 @@ async fn import_dump_v3_rubygems_with_settings() { | ||||
|     assert_eq!(code, 200); | ||||
|     assert_eq!( | ||||
|         tasks["results"][0], | ||||
|         json!({"uid": 92, "indexUid": "rubygems", "status": "succeeded", "type": "documentAdditionOrUpdate", "details": {"receivedDocuments": 0, "indexedDocuments": 1042}, "duration": "PT14.034672S", "enqueuedAt": "2021-09-08T08:40:31.390775Z", "startedAt": "2021-09-08T08:51:39.060642Z", "finishedAt": "2021-09-08T08:51:53.095314Z"}) | ||||
|         json!({"uid": 92, "indexUid": "rubygems", "status": "succeeded", "type": "documentAdditionOrUpdate", "canceledBy": null, "details": {"receivedDocuments": 0, "indexedDocuments": 1042}, "error": null, "duration": "PT14.034672S", "enqueuedAt": "2021-09-08T08:40:31.390775Z", "startedAt": "2021-09-08T08:51:39.060642Z", "finishedAt": "2021-09-08T08:51:53.095314Z"}) | ||||
|     ); | ||||
|  | ||||
|     // finally we're just going to check that we can still get a few documents by id | ||||
| @@ -433,7 +433,7 @@ async fn import_dump_v4_movie_raw() { | ||||
|     assert_eq!(code, 200); | ||||
|     assert_eq!( | ||||
|         tasks, | ||||
|         json!({ "results": [{"uid": 0, "indexUid": "indexUID", "status": "succeeded", "type": "documentAdditionOrUpdate", "details": { "receivedDocuments": 0, "indexedDocuments": 31944 }, "duration": "PT41.751156S", "enqueuedAt": "2021-09-08T08:30:30.550282Z", "startedAt": "2021-09-08T08:30:30.553012Z", "finishedAt": "2021-09-08T08:31:12.304168Z" }], "limit" : 20, "from": 0, "next": null }) | ||||
|         json!({ "results": [{"uid": 0, "indexUid": "indexUID", "status": "succeeded", "type": "documentAdditionOrUpdate", "canceledBy": null, "details": { "receivedDocuments": 0, "indexedDocuments": 31944 }, "error": null, "duration": "PT41.751156S", "enqueuedAt": "2021-09-08T08:30:30.550282Z", "startedAt": "2021-09-08T08:30:30.553012Z", "finishedAt": "2021-09-08T08:31:12.304168Z" }], "limit" : 20, "from": 0, "next": null }) | ||||
|     ); | ||||
|  | ||||
|     // finally we're just going to check that we can still get a few documents by id | ||||
| @@ -496,7 +496,7 @@ async fn import_dump_v4_movie_with_settings() { | ||||
|     assert_eq!(code, 200); | ||||
|     assert_eq!( | ||||
|         tasks, | ||||
|         json!({ "results": [{ "uid": 1, "indexUid": "indexUID", "status": "succeeded", "type": "settingsUpdate", "details": { "displayedAttributes": ["title", "genres", "overview", "poster", "release_date"], "searchableAttributes": ["title", "overview"], "filterableAttributes": ["genres"], "stopWords": ["of", "the"] }, "duration": "PT37.488777S", "enqueuedAt": "2021-09-08T08:24:02.323444Z", "startedAt": "2021-09-08T08:24:02.324145Z", "finishedAt": "2021-09-08T08:24:39.812922Z" }, { "uid": 0, "indexUid": "indexUID", "status": "succeeded", "type": "documentAdditionOrUpdate", "details": { "receivedDocuments": 0, "indexedDocuments": 31944 }, "duration": "PT39.941318S", "enqueuedAt": "2021-09-08T08:21:14.742672Z", "startedAt": "2021-09-08T08:21:14.750166Z", "finishedAt": "2021-09-08T08:21:54.691484Z" }], "limit": 20, "from": 1, "next": null }) | ||||
|         json!({ "results": [{ "uid": 1, "indexUid": "indexUID", "status": "succeeded", "type": "settingsUpdate", "canceledBy": null, "details": { "displayedAttributes": ["title", "genres", "overview", "poster", "release_date"], "searchableAttributes": ["title", "overview"], "filterableAttributes": ["genres"], "stopWords": ["of", "the"] }, "error": null, "duration": "PT37.488777S", "enqueuedAt": "2021-09-08T08:24:02.323444Z", "startedAt": "2021-09-08T08:24:02.324145Z", "finishedAt": "2021-09-08T08:24:39.812922Z" }, { "uid": 0, "indexUid": "indexUID", "status": "succeeded", "type": "documentAdditionOrUpdate", "canceledBy": null, "details": { "receivedDocuments": 0, "indexedDocuments": 31944 }, "error": null, "duration": "PT39.941318S", "enqueuedAt": "2021-09-08T08:21:14.742672Z", "startedAt": "2021-09-08T08:21:14.750166Z", "finishedAt": "2021-09-08T08:21:54.691484Z" }], "limit": 20, "from": 1, "next": null }) | ||||
|     ); | ||||
|  | ||||
|     // finally we're just going to check that we can still get a few documents by id | ||||
| @@ -559,7 +559,7 @@ async fn import_dump_v4_rubygems_with_settings() { | ||||
|     assert_eq!(code, 200); | ||||
|     assert_eq!( | ||||
|         tasks["results"][0], | ||||
|         json!({ "uid": 92, "indexUid": "rubygems", "status": "succeeded", "type": "documentAdditionOrUpdate", "details": {"receivedDocuments": 0, "indexedDocuments": 1042}, "duration": "PT14.034672S", "enqueuedAt": "2021-09-08T08:40:31.390775Z", "startedAt": "2021-09-08T08:51:39.060642Z", "finishedAt": "2021-09-08T08:51:53.095314Z"}) | ||||
|         json!({ "uid": 92, "indexUid": "rubygems", "status": "succeeded", "type": "documentAdditionOrUpdate", "canceledBy": null, "details": {"receivedDocuments": 0, "indexedDocuments": 1042}, "error": null, "duration": "PT14.034672S", "enqueuedAt": "2021-09-08T08:40:31.390775Z", "startedAt": "2021-09-08T08:51:39.060642Z", "finishedAt": "2021-09-08T08:51:53.095314Z"}) | ||||
|     ); | ||||
|  | ||||
|     // finally we're just going to check that we can still get a few documents by id | ||||
|   | ||||
| @@ -189,7 +189,7 @@ async fn error_create_with_invalid_index_uid() { | ||||
|     let (response, code) = index.create(None).await; | ||||
|  | ||||
|     let expected_response = json!({ | ||||
|         "message": "invalid index uid `test test#!`, the uid must be an integer or a string containing only alphanumeric characters a-z A-Z 0-9, hyphens - and underscores _.", | ||||
|         "message": "`test test#!` is not a valid index uid. Index uid can be an integer or a string containing only alphanumeric characters, hyphens (-) and underscores (_).", | ||||
|         "code": "invalid_index_uid", | ||||
|         "type": "invalid_request", | ||||
|         "link": "https://docs.meilisearch.com/errors#invalid_index_uid" | ||||
|   | ||||
| @@ -70,7 +70,7 @@ async fn filter_invalid_syntax_object() { | ||||
|     index.wait_task(1).await; | ||||
|  | ||||
|     let expected_response = json!({ | ||||
|         "message": "Was expecting an operation `=`, `!=`, `>=`, `>`, `<=`, `<`, `TO`, `EXISTS`, `NOT EXISTS`, or `_geoRadius` at `title & Glass`.\n1:14 title & Glass", | ||||
|         "message": "Was expecting an operation `=`, `!=`, `>=`, `>`, `<=`, `<`, `IN`, `NOT IN`, `TO`, `EXISTS`, `NOT EXISTS`, or `_geoRadius` at `title & Glass`.\n1:14 title & Glass", | ||||
|         "code": "invalid_filter", | ||||
|         "type": "invalid_request", | ||||
|         "link": "https://docs.meilisearch.com/errors#invalid_filter" | ||||
| @@ -95,7 +95,7 @@ async fn filter_invalid_syntax_array() { | ||||
|     index.wait_task(1).await; | ||||
|  | ||||
|     let expected_response = json!({ | ||||
|         "message": "Was expecting an operation `=`, `!=`, `>=`, `>`, `<=`, `<`, `TO`, `EXISTS`, `NOT EXISTS`, or `_geoRadius` at `title & Glass`.\n1:14 title & Glass", | ||||
|         "message": "Was expecting an operation `=`, `!=`, `>=`, `>`, `<=`, `<`, `IN`, `NOT IN`, `TO`, `EXISTS`, `NOT EXISTS`, or `_geoRadius` at `title & Glass`.\n1:14 title & Glass", | ||||
|         "code": "invalid_filter", | ||||
|         "type": "invalid_request", | ||||
|         "link": "https://docs.meilisearch.com/errors#invalid_filter" | ||||
|   | ||||
| @@ -182,7 +182,7 @@ async fn error_update_setting_unexisting_index_invalid_uid() { | ||||
|     assert_eq!(code, 400); | ||||
|  | ||||
|     let expected = json!({ | ||||
|         "message": "invalid index uid `test##!  `, the uid must be an integer or a string containing only alphanumeric characters a-z A-Z 0-9, hyphens - and underscores _.", | ||||
|         "message": "`test##!  ` is not a valid index uid. Index uid can be an integer or a string containing only alphanumeric characters, hyphens (-) and underscores (_).", | ||||
|         "code": "invalid_index_uid", | ||||
|         "type": "invalid_request", | ||||
|         "link": "https://docs.meilisearch.com/errors#invalid_index_uid"}); | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| use meili_snap::insta::assert_json_snapshot; | ||||
| use meili_snap::insta::{self, assert_json_snapshot}; | ||||
| use serde_json::json; | ||||
| use time::format_description::well_known::Rfc3339; | ||||
| use time::OffsetDateTime; | ||||
| @@ -67,37 +67,37 @@ async fn list_tasks_with_star_filters() { | ||||
|     index | ||||
|         .add_documents(serde_json::from_str(include_str!("../assets/test_set.json")).unwrap(), None) | ||||
|         .await; | ||||
|     let (response, code) = index.service.get("/tasks?indexUid=test").await; | ||||
|     let (response, code) = index.service.get("/tasks?indexUids=test").await; | ||||
|     assert_eq!(code, 200); | ||||
|     assert_eq!(response["results"].as_array().unwrap().len(), 2); | ||||
|  | ||||
|     let (response, code) = index.service.get("/tasks?indexUid=*").await; | ||||
|     let (response, code) = index.service.get("/tasks?indexUids=*").await; | ||||
|     assert_eq!(code, 200); | ||||
|     assert_eq!(response["results"].as_array().unwrap().len(), 2); | ||||
|  | ||||
|     let (response, code) = index.service.get("/tasks?indexUid=*,pasteque").await; | ||||
|     let (response, code) = index.service.get("/tasks?indexUids=*,pasteque").await; | ||||
|     assert_eq!(code, 200); | ||||
|     assert_eq!(response["results"].as_array().unwrap().len(), 2); | ||||
|  | ||||
|     let (response, code) = index.service.get("/tasks?type=*").await; | ||||
|     let (response, code) = index.service.get("/tasks?types=*").await; | ||||
|     assert_eq!(code, 200); | ||||
|     assert_eq!(response["results"].as_array().unwrap().len(), 2); | ||||
|  | ||||
|     let (response, code) = | ||||
|         index.service.get("/tasks?type=*,documentAdditionOrUpdate&status=*").await; | ||||
|         index.service.get("/tasks?types=*,documentAdditionOrUpdate&statuses=*").await; | ||||
|     assert_eq!(code, 200, "{:?}", response); | ||||
|     assert_eq!(response["results"].as_array().unwrap().len(), 2); | ||||
|  | ||||
|     let (response, code) = index | ||||
|         .service | ||||
|         .get("/tasks?type=*,documentAdditionOrUpdate&status=*,failed&indexUid=test") | ||||
|         .get("/tasks?types=*,documentAdditionOrUpdate&statuses=*,failed&indexUids=test") | ||||
|         .await; | ||||
|     assert_eq!(code, 200, "{:?}", response); | ||||
|     assert_eq!(response["results"].as_array().unwrap().len(), 2); | ||||
|  | ||||
|     let (response, code) = index | ||||
|         .service | ||||
|         .get("/tasks?type=*,documentAdditionOrUpdate&status=*,failed&indexUid=test,*") | ||||
|         .get("/tasks?types=*,documentAdditionOrUpdate&statuses=*,failed&indexUids=test,*") | ||||
|         .await; | ||||
|     assert_eq!(code, 200, "{:?}", response); | ||||
|     assert_eq!(response["results"].as_array().unwrap().len(), 2); | ||||
| @@ -173,6 +173,131 @@ async fn list_tasks_status_and_type_filtered() { | ||||
|     assert_eq!(response["results"].as_array().unwrap().len(), 2); | ||||
| } | ||||
|  | ||||
| #[actix_rt::test] | ||||
| async fn get_task_filter_error() { | ||||
|     let server = Server::new().await; | ||||
|  | ||||
|     let (response, code) = server.tasks_filter(json!( { "lol": "pied" })).await; | ||||
|     assert_eq!(code, 400, "{}", response); | ||||
|     insta::assert_json_snapshot!(response, @r###" | ||||
|     { | ||||
|       "message": "Query deserialize error: unknown field `lol`", | ||||
|       "code": "bad_request", | ||||
|       "type": "invalid_request", | ||||
|       "link": "https://docs.meilisearch.com/errors#bad_request" | ||||
|     } | ||||
|     "###); | ||||
|  | ||||
|     let (response, code) = server.tasks_filter(json!( { "uids": "pied" })).await; | ||||
|     assert_eq!(code, 400, "{}", response); | ||||
|     insta::assert_json_snapshot!(response, @r###" | ||||
|     { | ||||
|       "message": "Task uid `pied` is invalid. It should only contain numeric characters.", | ||||
|       "code": "invalid_task_uids_filter", | ||||
|       "type": "invalid_request", | ||||
|       "link": "https://docs.meilisearch.com/errors#invalid_task_uids_filter" | ||||
|     } | ||||
|     "###); | ||||
|  | ||||
|     let (response, code) = server.tasks_filter(json!( { "from": "pied" })).await; | ||||
|     assert_eq!(code, 400, "{}", response); | ||||
|     insta::assert_json_snapshot!(response, @r###" | ||||
|     { | ||||
|       "message": "Query deserialize error: invalid digit found in string", | ||||
|       "code": "bad_request", | ||||
|       "type": "invalid_request", | ||||
|       "link": "https://docs.meilisearch.com/errors#bad_request" | ||||
|     } | ||||
|     "###); | ||||
|  | ||||
|     let (response, code) = server.tasks_filter(json!( { "beforeStartedAt": "pied" })).await; | ||||
|     assert_eq!(code, 400, "{}", response); | ||||
|     insta::assert_json_snapshot!(response, @r###" | ||||
|     { | ||||
|       "message": "Task `beforeStartedAt` `pied` is invalid. It should follow the YYYY-MM-DD or RFC 3339 date-time format.", | ||||
|       "code": "invalid_task_date_filter", | ||||
|       "type": "invalid_request", | ||||
|       "link": "https://docs.meilisearch.com/errors#invalid_task_date_filter" | ||||
|     } | ||||
|     "###); | ||||
| } | ||||
|  | ||||
| #[actix_rt::test] | ||||
| async fn delete_task_filter_error() { | ||||
|     let server = Server::new().await; | ||||
|  | ||||
|     let (response, code) = server.delete_tasks(json!(null)).await; | ||||
|     assert_eq!(code, 400, "{}", response); | ||||
|     insta::assert_json_snapshot!(response, @r###" | ||||
|     { | ||||
|       "message": "Query parameters to filter the tasks to delete are missing. Available query parameters are: `uids`, `indexUids`, `statuses`, `types`, `beforeEnqueuedAt`, `afterEnqueuedAt`, `beforeStartedAt`, `afterStartedAt`, `beforeFinishedAt`, `afterFinishedAt`.", | ||||
|       "code": "missing_task_filters", | ||||
|       "type": "invalid_request", | ||||
|       "link": "https://docs.meilisearch.com/errors#missing_task_filters" | ||||
|     } | ||||
|     "###); | ||||
|  | ||||
|     let (response, code) = server.delete_tasks(json!({ "lol": "pied" })).await; | ||||
|     assert_eq!(code, 400, "{}", response); | ||||
|     insta::assert_json_snapshot!(response, @r###" | ||||
|     { | ||||
|       "message": "Query deserialize error: unknown field `lol`", | ||||
|       "code": "bad_request", | ||||
|       "type": "invalid_request", | ||||
|       "link": "https://docs.meilisearch.com/errors#bad_request" | ||||
|     } | ||||
|     "###); | ||||
|  | ||||
|     let (response, code) = server.delete_tasks(json!({ "uids": "pied" })).await; | ||||
|     assert_eq!(code, 400, "{}", response); | ||||
|     insta::assert_json_snapshot!(response, @r###" | ||||
|     { | ||||
|       "message": "Task uid `pied` is invalid. It should only contain numeric characters.", | ||||
|       "code": "invalid_task_uids_filter", | ||||
|       "type": "invalid_request", | ||||
|       "link": "https://docs.meilisearch.com/errors#invalid_task_uids_filter" | ||||
|     } | ||||
|     "###); | ||||
| } | ||||
|  | ||||
| #[actix_rt::test] | ||||
| async fn cancel_task_filter_error() { | ||||
|     let server = Server::new().await; | ||||
|  | ||||
|     let (response, code) = server.cancel_tasks(json!(null)).await; | ||||
|     assert_eq!(code, 400, "{}", response); | ||||
|     insta::assert_json_snapshot!(response, @r###" | ||||
|     { | ||||
|       "message": "Query parameters to filter the tasks to cancel are missing. Available query parameters are: `uids`, `indexUids`, `statuses`, `types`, `beforeEnqueuedAt`, `afterEnqueuedAt`, `beforeStartedAt`, `afterStartedAt`, `beforeFinishedAt`, `afterFinishedAt`.", | ||||
|       "code": "missing_task_filters", | ||||
|       "type": "invalid_request", | ||||
|       "link": "https://docs.meilisearch.com/errors#missing_task_filters" | ||||
|     } | ||||
|     "###); | ||||
|  | ||||
|     let (response, code) = server.cancel_tasks(json!({ "lol": "pied" })).await; | ||||
|     assert_eq!(code, 400, "{}", response); | ||||
|     insta::assert_json_snapshot!(response, @r###" | ||||
|     { | ||||
|       "message": "Query deserialize error: unknown field `lol`", | ||||
|       "code": "bad_request", | ||||
|       "type": "invalid_request", | ||||
|       "link": "https://docs.meilisearch.com/errors#bad_request" | ||||
|     } | ||||
|     "###); | ||||
|  | ||||
|     let (response, code) = server.cancel_tasks(json!({ "uids": "pied" })).await; | ||||
|     assert_eq!(code, 400, "{}", response); | ||||
|     insta::assert_json_snapshot!(response, @r###" | ||||
|     { | ||||
|       "message": "Task uid `pied` is invalid. It should only contain numeric characters.", | ||||
|       "code": "invalid_task_uids_filter", | ||||
|       "type": "invalid_request", | ||||
|       "link": "https://docs.meilisearch.com/errors#invalid_task_uids_filter" | ||||
|     } | ||||
|     "###); | ||||
| } | ||||
|  | ||||
| macro_rules! assert_valid_summarized_task { | ||||
|     ($response:expr, $task_type:literal, $index:literal) => {{ | ||||
|         assert_eq!($response.as_object().unwrap().len(), 5); | ||||
| @@ -231,10 +356,12 @@ async fn test_summarized_document_addition_or_update() { | ||||
|       "indexUid": "test", | ||||
|       "status": "succeeded", | ||||
|       "type": "documentAdditionOrUpdate", | ||||
|       "canceledBy": null, | ||||
|       "details": { | ||||
|         "receivedDocuments": 1, | ||||
|         "indexedDocuments": 1 | ||||
|       }, | ||||
|       "error": null, | ||||
|       "duration": "[duration]", | ||||
|       "enqueuedAt": "[date]", | ||||
|       "startedAt": "[date]", | ||||
| @@ -253,10 +380,12 @@ async fn test_summarized_document_addition_or_update() { | ||||
|       "indexUid": "test", | ||||
|       "status": "succeeded", | ||||
|       "type": "documentAdditionOrUpdate", | ||||
|       "canceledBy": null, | ||||
|       "details": { | ||||
|         "receivedDocuments": 1, | ||||
|         "indexedDocuments": 1 | ||||
|       }, | ||||
|       "error": null, | ||||
|       "duration": "[duration]", | ||||
|       "enqueuedAt": "[date]", | ||||
|       "startedAt": "[date]", | ||||
| @@ -280,9 +409,10 @@ async fn test_summarized_delete_batch() { | ||||
|       "indexUid": "test", | ||||
|       "status": "failed", | ||||
|       "type": "documentDeletion", | ||||
|       "canceledBy": null, | ||||
|       "details": { | ||||
|         "matchedDocuments": 3, | ||||
|         "deletedDocuments": null | ||||
|         "providedIds": 3, | ||||
|         "deletedDocuments": 0 | ||||
|       }, | ||||
|       "error": { | ||||
|         "message": "Index `test` not found.", | ||||
| @@ -309,10 +439,12 @@ async fn test_summarized_delete_batch() { | ||||
|       "indexUid": "test", | ||||
|       "status": "succeeded", | ||||
|       "type": "documentDeletion", | ||||
|       "canceledBy": null, | ||||
|       "details": { | ||||
|         "matchedDocuments": 1, | ||||
|         "providedIds": 1, | ||||
|         "deletedDocuments": 0 | ||||
|       }, | ||||
|       "error": null, | ||||
|       "duration": "[duration]", | ||||
|       "enqueuedAt": "[date]", | ||||
|       "startedAt": "[date]", | ||||
| @@ -336,9 +468,10 @@ async fn test_summarized_delete_document() { | ||||
|       "indexUid": "test", | ||||
|       "status": "failed", | ||||
|       "type": "documentDeletion", | ||||
|       "canceledBy": null, | ||||
|       "details": { | ||||
|         "matchedDocuments": 1, | ||||
|         "deletedDocuments": null | ||||
|         "providedIds": 1, | ||||
|         "deletedDocuments": 0 | ||||
|       }, | ||||
|       "error": { | ||||
|         "message": "Index `test` not found.", | ||||
| @@ -365,10 +498,12 @@ async fn test_summarized_delete_document() { | ||||
|       "indexUid": "test", | ||||
|       "status": "succeeded", | ||||
|       "type": "documentDeletion", | ||||
|       "canceledBy": null, | ||||
|       "details": { | ||||
|         "matchedDocuments": 1, | ||||
|         "providedIds": 1, | ||||
|         "deletedDocuments": 0 | ||||
|       }, | ||||
|       "error": null, | ||||
|       "duration": "[duration]", | ||||
|       "enqueuedAt": "[date]", | ||||
|       "startedAt": "[date]", | ||||
| @@ -394,6 +529,7 @@ async fn test_summarized_settings_update() { | ||||
|       "indexUid": "test", | ||||
|       "status": "failed", | ||||
|       "type": "settingsUpdate", | ||||
|       "canceledBy": null, | ||||
|       "details": { | ||||
|         "rankingRules": [ | ||||
|           "custom" | ||||
| @@ -423,6 +559,7 @@ async fn test_summarized_settings_update() { | ||||
|       "indexUid": "test", | ||||
|       "status": "succeeded", | ||||
|       "type": "settingsUpdate", | ||||
|       "canceledBy": null, | ||||
|       "details": { | ||||
|         "displayedAttributes": [ | ||||
|           "doggos", | ||||
| @@ -436,6 +573,7 @@ async fn test_summarized_settings_update() { | ||||
|           "iq" | ||||
|         ] | ||||
|       }, | ||||
|       "error": null, | ||||
|       "duration": "[duration]", | ||||
|       "enqueuedAt": "[date]", | ||||
|       "startedAt": "[date]", | ||||
| @@ -459,9 +597,11 @@ async fn test_summarized_index_creation() { | ||||
|       "indexUid": "test", | ||||
|       "status": "succeeded", | ||||
|       "type": "indexCreation", | ||||
|       "canceledBy": null, | ||||
|       "details": { | ||||
|         "primaryKey": null | ||||
|       }, | ||||
|       "error": null, | ||||
|       "duration": "[duration]", | ||||
|       "enqueuedAt": "[date]", | ||||
|       "startedAt": "[date]", | ||||
| @@ -480,6 +620,7 @@ async fn test_summarized_index_creation() { | ||||
|       "indexUid": "test", | ||||
|       "status": "failed", | ||||
|       "type": "indexCreation", | ||||
|       "canceledBy": null, | ||||
|       "details": { | ||||
|         "primaryKey": "doggos" | ||||
|       }, | ||||
| @@ -512,6 +653,10 @@ async fn test_summarized_index_deletion() { | ||||
|       "indexUid": "test", | ||||
|       "status": "failed", | ||||
|       "type": "indexDeletion", | ||||
|       "canceledBy": null, | ||||
|       "details": { | ||||
|         "deletedDocuments": 0 | ||||
|       }, | ||||
|       "error": { | ||||
|         "message": "Index `test` not found.", | ||||
|         "code": "index_not_found", | ||||
| @@ -538,9 +683,11 @@ async fn test_summarized_index_deletion() { | ||||
|       "indexUid": "test", | ||||
|       "status": "succeeded", | ||||
|       "type": "indexDeletion", | ||||
|       "canceledBy": null, | ||||
|       "details": { | ||||
|         "deletedDocuments": 1 | ||||
|       }, | ||||
|       "error": null, | ||||
|       "duration": "[duration]", | ||||
|       "enqueuedAt": "[date]", | ||||
|       "startedAt": "[date]", | ||||
| @@ -560,9 +707,11 @@ async fn test_summarized_index_deletion() { | ||||
|       "indexUid": "test", | ||||
|       "status": "succeeded", | ||||
|       "type": "indexDeletion", | ||||
|       "canceledBy": null, | ||||
|       "details": { | ||||
|         "deletedDocuments": 1 | ||||
|       }, | ||||
|       "error": null, | ||||
|       "duration": "[duration]", | ||||
|       "enqueuedAt": "[date]", | ||||
|       "startedAt": "[date]", | ||||
| @@ -587,6 +736,7 @@ async fn test_summarized_index_update() { | ||||
|       "indexUid": "test", | ||||
|       "status": "failed", | ||||
|       "type": "indexUpdate", | ||||
|       "canceledBy": null, | ||||
|       "details": { | ||||
|         "primaryKey": null | ||||
|       }, | ||||
| @@ -614,6 +764,7 @@ async fn test_summarized_index_update() { | ||||
|       "indexUid": "test", | ||||
|       "status": "failed", | ||||
|       "type": "indexUpdate", | ||||
|       "canceledBy": null, | ||||
|       "details": { | ||||
|         "primaryKey": "bones" | ||||
|       }, | ||||
| @@ -644,9 +795,11 @@ async fn test_summarized_index_update() { | ||||
|       "indexUid": "test", | ||||
|       "status": "succeeded", | ||||
|       "type": "indexUpdate", | ||||
|       "canceledBy": null, | ||||
|       "details": { | ||||
|         "primaryKey": null | ||||
|       }, | ||||
|       "error": null, | ||||
|       "duration": "[duration]", | ||||
|       "enqueuedAt": "[date]", | ||||
|       "startedAt": "[date]", | ||||
| @@ -665,9 +818,11 @@ async fn test_summarized_index_update() { | ||||
|       "indexUid": "test", | ||||
|       "status": "succeeded", | ||||
|       "type": "indexUpdate", | ||||
|       "canceledBy": null, | ||||
|       "details": { | ||||
|         "primaryKey": "bones" | ||||
|       }, | ||||
|       "error": null, | ||||
|       "duration": "[duration]", | ||||
|       "enqueuedAt": "[date]", | ||||
|       "startedAt": "[date]", | ||||
| @@ -694,6 +849,7 @@ async fn test_summarized_index_swap() { | ||||
|       "indexUid": null, | ||||
|       "status": "failed", | ||||
|       "type": "indexSwap", | ||||
|       "canceledBy": null, | ||||
|       "details": { | ||||
|         "swaps": [ | ||||
|           { | ||||
| @@ -734,6 +890,7 @@ async fn test_summarized_index_swap() { | ||||
|       "indexUid": null, | ||||
|       "status": "succeeded", | ||||
|       "type": "indexSwap", | ||||
|       "canceledBy": null, | ||||
|       "details": { | ||||
|         "swaps": [ | ||||
|           { | ||||
| @@ -744,6 +901,7 @@ async fn test_summarized_index_swap() { | ||||
|           } | ||||
|         ] | ||||
|       }, | ||||
|       "error": null, | ||||
|       "duration": "[duration]", | ||||
|       "enqueuedAt": "[date]", | ||||
|       "startedAt": "[date]", | ||||
| @@ -759,7 +917,7 @@ async fn test_summarized_task_cancelation() { | ||||
|     // to avoid being flaky we're only going to cancel an already finished task :( | ||||
|     index.create(None).await; | ||||
|     index.wait_task(0).await; | ||||
|     server.cancel_task(json!({ "uid": [0] })).await; | ||||
|     server.cancel_tasks(json!({ "uids": [0] })).await; | ||||
|     index.wait_task(1).await; | ||||
|     let (task, _) = index.get_task(1).await; | ||||
|     assert_json_snapshot!(task,  | ||||
| @@ -770,11 +928,13 @@ async fn test_summarized_task_cancelation() { | ||||
|       "indexUid": null, | ||||
|       "status": "succeeded", | ||||
|       "type": "taskCancelation", | ||||
|       "canceledBy": null, | ||||
|       "details": { | ||||
|         "matchedTasks": 1, | ||||
|         "canceledTasks": 0, | ||||
|         "originalQuery": "uid=0" | ||||
|         "originalFilter": "?uids=0" | ||||
|       }, | ||||
|       "error": null, | ||||
|       "duration": "[duration]", | ||||
|       "enqueuedAt": "[date]", | ||||
|       "startedAt": "[date]", | ||||
| @@ -790,7 +950,7 @@ async fn test_summarized_task_deletion() { | ||||
|     // to avoid being flaky we're only going to delete an already finished task :( | ||||
|     index.create(None).await; | ||||
|     index.wait_task(0).await; | ||||
|     server.delete_task(json!({ "uid": [0] })).await; | ||||
|     server.delete_tasks(json!({ "uids": [0] })).await; | ||||
|     index.wait_task(1).await; | ||||
|     let (task, _) = index.get_task(1).await; | ||||
|     assert_json_snapshot!(task,  | ||||
| @@ -801,11 +961,13 @@ async fn test_summarized_task_deletion() { | ||||
|       "indexUid": null, | ||||
|       "status": "succeeded", | ||||
|       "type": "taskDeletion", | ||||
|       "canceledBy": null, | ||||
|       "details": { | ||||
|         "matchedTasks": 1, | ||||
|         "deletedTasks": 1, | ||||
|         "originalQuery": "uid=0" | ||||
|         "originalFilter": "?uids=0" | ||||
|       }, | ||||
|       "error": null, | ||||
|       "duration": "[duration]", | ||||
|       "enqueuedAt": "[date]", | ||||
|       "startedAt": "[date]", | ||||
| @@ -821,13 +983,18 @@ async fn test_summarized_dump_creation() { | ||||
|     server.wait_task(0).await; | ||||
|     let (task, _) = server.get_task(0).await; | ||||
|     assert_json_snapshot!(task,  | ||||
|         { ".duration" => "[duration]", ".enqueuedAt" => "[date]", ".startedAt" => "[date]", ".finishedAt" => "[date]" }, | ||||
|         { ".details.dumpUid" => "[dumpUid]", ".duration" => "[duration]", ".enqueuedAt" => "[date]", ".startedAt" => "[date]", ".finishedAt" => "[date]" }, | ||||
|         @r###" | ||||
|     { | ||||
|       "uid": 0, | ||||
|       "indexUid": null, | ||||
|       "status": "succeeded", | ||||
|       "type": "dumpCreation", | ||||
|       "canceledBy": null, | ||||
|       "details": { | ||||
|         "dumpUid": "[dumpUid]" | ||||
|       }, | ||||
|       "error": null, | ||||
|       "duration": "[duration]", | ||||
|       "enqueuedAt": "[date]", | ||||
|       "startedAt": "[date]", | ||||
|   | ||||
		Reference in New Issue
	
	Block a user