use meili_snap::{json_string, snapshot}; use crate::common::{GetAllDocumentsOptions, Server}; use crate::json; #[actix_rt::test] async fn delete_one_document_unexisting_index() { let server = Server::new().await; let index = server.index("test"); let (task, code) = index.delete_document(0).await; assert_eq!(code, 202); let response = index.wait_task(task.uid()).await; assert_eq!(response["status"], "failed"); } #[actix_rt::test] async fn delete_one_unexisting_document() { let server = Server::new().await; let index = server.index("test"); index.create(None).await; let (response, code) = index.delete_document(0).await; assert_eq!(code, 202, "{}", response); let update = index.wait_task(response.uid()).await; assert_eq!(update["status"], "succeeded"); } #[actix_rt::test] async fn delete_one_document() { let server = Server::new().await; let index = server.index("test"); let (task,_status_code) = index.add_documents(json!([{ "id": 0, "content": "foobar" }]), None).await; index.wait_task(task.uid()).await.succeeded(); let (task,status_code) = server.index("test").delete_document(0).await; assert_eq!(status_code, 202); index.wait_task(task.uid()).await.succeeded(); let (_response, code) = index.get_document(0, None).await; assert_eq!(code, 404); } #[actix_rt::test] async fn clear_all_documents_unexisting_index() { let server = Server::new().await; let index = server.index("test"); let (task, code) = index.clear_all_documents().await; assert_eq!(code, 202); let response = index.wait_task(task.uid()).await; assert_eq!(response["status"], "failed"); } #[actix_rt::test] async fn clear_all_documents() { let server = Server::new().await; let index = server.index("test"); let (task,_status_code) = index .add_documents( json!([{ "id": 1, "content": "foobar" }, { "id": 0, "content": "foobar" }]), None, ) .await; index.wait_task(task.uid()).await.succeeded(); let (task, code) = index.clear_all_documents().await; assert_eq!(code, 202); let _update = index.wait_task(task.uid()).await; let (response, code) = index.get_all_documents(GetAllDocumentsOptions::default()).await; assert_eq!(code, 200); assert!(response["results"].as_array().unwrap().is_empty()); } #[actix_rt::test] async fn clear_all_documents_empty_index() { let server = Server::new().await; let index = server.index("test"); let (task,_status_code) = index.create(None).await; index.wait_task(task.uid()).await.succeeded(); let (task, code) = index.clear_all_documents().await; assert_eq!(code, 202); let _update = index.wait_task(task.uid()).await; let (response, code) = index.get_all_documents(GetAllDocumentsOptions::default()).await; index.wait_task(response.uid()).await.succeeded(); assert_eq!(code, 200); assert!(response["results"].as_array().unwrap().is_empty()); } #[actix_rt::test] async fn error_delete_batch_unexisting_index() { let server = Server::new().await; let index = server.index("test"); let (task, code) = index.delete_batch(vec![]).await; let expected_response = json!({ "message": "Index `test` not found.", "code": "index_not_found", "type": "invalid_request", "link": "https://docs.meilisearch.com/errors#index_not_found" }); assert_eq!(code, 202); let response = index.wait_task(task.uid()).await; assert_eq!(response["status"], "failed"); assert_eq!(response["error"], expected_response); } #[actix_rt::test] async fn delete_batch() { let server = Server::new().await; let index = server.index("test"); let (task,_status_code) = index.add_documents(json!([{ "id": 1, "content": "foobar" }, { "id": 0, "content": "foobar" }, { "id": 3, "content": "foobar" }]), Some("id")).await; index.wait_task(task.uid()).await.succeeded(); let (task, code) = index.delete_batch(vec![1, 0]).await; assert_eq!(code, 202); let _update = index.wait_task(task.uid()).await; let (response, code) = index.get_all_documents(GetAllDocumentsOptions::default()).await; assert_eq!(code, 200); assert_eq!(response["results"].as_array().unwrap().len(), 1); assert_eq!(response["results"][0]["id"], json!(3)); } #[actix_rt::test] async fn delete_no_document_batch() { let server = Server::new().await; let index = server.index("test"); let (task,_status_code) = index.add_documents(json!([{ "id": 1, "content": "foobar" }, { "id": 0, "content": "foobar" }, { "id": 3, "content": "foobar" }]), Some("id")).await; index.wait_task(task.uid()).await.succeeded(); let (_response, code) = index.delete_batch(vec![]).await; assert_eq!(code, 202, "{}", _response); let _update = index.wait_task(_response.uid()).await; let (response, code) = index.get_all_documents(GetAllDocumentsOptions::default()).await; assert_eq!(code, 200); assert_eq!(response["results"].as_array().unwrap().len(), 3); } #[actix_rt::test] async fn delete_document_by_filter() { let server = Server::new().await; let index = server.index("doggo"); index.update_settings_filterable_attributes(json!(["color"])).await; let (task,_status_code) = index .add_documents( json!([ { "id": 0, "color": "red" }, { "id": 1, "color": "blue" }, { "id": 2, "color": "blue" }, { "id": 3 }, ]), Some("id"), ) .await; index.wait_task(task.uid()).await.succeeded(); let (stats, _) = index.stats().await; snapshot!(json_string!(stats), @r###" { "numberOfDocuments": 4, "isIndexing": false, "fieldDistribution": { "color": 3, "id": 4 } } "###); let (response, code) = index.delete_document_by_filter(json!({ "filter": "color = blue"})).await; snapshot!(code, @"202 Accepted"); snapshot!(json_string!(response, { ".enqueuedAt" => "[date]" }), @r###" { "taskUid": 2, "indexUid": "doggo", "status": "enqueued", "type": "documentDeletion", "enqueuedAt": "[date]" } "###); let response = index.wait_task(response.uid()).await; snapshot!(json_string!(response, { ".enqueuedAt" => "[date]", ".startedAt" => "[date]", ".finishedAt" => "[date]", ".duration" => "[duration]" }), @r###" { "uid": 2, "batchUid": 2, "indexUid": "doggo", "status": "succeeded", "type": "documentDeletion", "canceledBy": null, "details": { "providedIds": 0, "deletedDocuments": 2, "originalFilter": "\"color = blue\"" }, "error": null, "duration": "[duration]", "enqueuedAt": "[date]", "startedAt": "[date]", "finishedAt": "[date]" } "###); let (stats, _) = index.stats().await; snapshot!(json_string!(stats), @r###" { "numberOfDocuments": 2, "isIndexing": false, "fieldDistribution": { "color": 1, "id": 2 } } "###); let (documents, code) = index.get_all_documents(GetAllDocumentsOptions::default()).await; snapshot!(code, @"200 OK"); snapshot!(json_string!(documents), @r###" { "results": [ { "id": 0, "color": "red" }, { "id": 3 } ], "offset": 0, "limit": 20, "total": 2 } "###); let (response, code) = index.delete_document_by_filter(json!({ "filter": "color NOT EXISTS"})).await; snapshot!(code, @"202 Accepted"); snapshot!(json_string!(response, { ".enqueuedAt" => "[date]", ".startedAt" => "[date]", ".finishedAt" => "[date]", ".duration" => "[duration]" }), @r###" { "taskUid": 3, "indexUid": "doggo", "status": "enqueued", "type": "documentDeletion", "enqueuedAt": "[date]" } "###); let response = index.wait_task(response.uid()).await; snapshot!(json_string!(response, { ".enqueuedAt" => "[date]", ".startedAt" => "[date]", ".finishedAt" => "[date]", ".duration" => "[duration]" }), @r###" { "uid": 3, "batchUid": 3, "indexUid": "doggo", "status": "succeeded", "type": "documentDeletion", "canceledBy": null, "details": { "providedIds": 0, "deletedDocuments": 1, "originalFilter": "\"color NOT EXISTS\"" }, "error": null, "duration": "[duration]", "enqueuedAt": "[date]", "startedAt": "[date]", "finishedAt": "[date]" } "###); let (stats, _) = index.stats().await; snapshot!(json_string!(stats), @r###" { "numberOfDocuments": 1, "isIndexing": false, "fieldDistribution": { "color": 1, "id": 1 } } "###); let (documents, code) = index.get_all_documents(GetAllDocumentsOptions::default()).await; snapshot!(code, @"200 OK"); snapshot!(json_string!(documents), @r###" { "results": [ { "id": 0, "color": "red" } ], "offset": 0, "limit": 20, "total": 1 } "###); } #[actix_rt::test] async fn delete_document_by_complex_filter() { let server = Server::new().await; let index = server.index("doggo"); index.update_settings_filterable_attributes(json!(["color"])).await; let (task,_status_code) = index .add_documents( json!([ { "id": 0, "color": "red" }, { "id": 1, "color": "blue" }, { "id": 2, "color": "blue" }, { "id": 3, "color": "green" }, { "id": 4 }, ]), Some("id"), ) .await; index.wait_task(task.uid()).await.succeeded(); let (response, code) = index .delete_document_by_filter( json!({ "filter": ["color != red", "color != green", "color EXISTS"] }), ) .await; snapshot!(code, @"202 Accepted"); snapshot!(json_string!(response, { ".enqueuedAt" => "[date]" }), @r###" { "taskUid": 2, "indexUid": "doggo", "status": "enqueued", "type": "documentDeletion", "enqueuedAt": "[date]" } "###); let response = index.wait_task(response.uid()).await; snapshot!(json_string!(response, { ".enqueuedAt" => "[date]", ".startedAt" => "[date]", ".finishedAt" => "[date]", ".duration" => "[duration]" }), @r###" { "uid": 2, "batchUid": 2, "indexUid": "doggo", "status": "succeeded", "type": "documentDeletion", "canceledBy": null, "details": { "providedIds": 0, "deletedDocuments": 2, "originalFilter": "[\"color != red\",\"color != green\",\"color EXISTS\"]" }, "error": null, "duration": "[duration]", "enqueuedAt": "[date]", "startedAt": "[date]", "finishedAt": "[date]" } "###); let (documents, code) = index.get_all_documents(GetAllDocumentsOptions::default()).await; snapshot!(code, @"200 OK"); snapshot!(json_string!(documents), @r###" { "results": [ { "id": 0, "color": "red" }, { "id": 3, "color": "green" }, { "id": 4 } ], "offset": 0, "limit": 20, "total": 3 } "###); let (response, code) = index .delete_document_by_filter(json!({ "filter": [["color = green", "color NOT EXISTS"]] })) .await; snapshot!(code, @"202 Accepted"); snapshot!(json_string!(response, { ".enqueuedAt" => "[date]", ".startedAt" => "[date]", ".finishedAt" => "[date]", ".duration" => "[duration]" }), @r###" { "taskUid": 3, "indexUid": "doggo", "status": "enqueued", "type": "documentDeletion", "enqueuedAt": "[date]" } "###); let response = index.wait_task(response.uid()).await; snapshot!(json_string!(response, { ".enqueuedAt" => "[date]", ".startedAt" => "[date]", ".finishedAt" => "[date]", ".duration" => "[duration]" }), @r###" { "uid": 3, "batchUid": 3, "indexUid": "doggo", "status": "succeeded", "type": "documentDeletion", "canceledBy": null, "details": { "providedIds": 0, "deletedDocuments": 2, "originalFilter": "[[\"color = green\",\"color NOT EXISTS\"]]" }, "error": null, "duration": "[duration]", "enqueuedAt": "[date]", "startedAt": "[date]", "finishedAt": "[date]" } "###); let (documents, code) = index.get_all_documents(GetAllDocumentsOptions::default()).await; snapshot!(code, @"200 OK"); snapshot!(json_string!(documents), @r###" { "results": [ { "id": 0, "color": "red" } ], "offset": 0, "limit": 20, "total": 1 } "###); }