2024-10-02 16:23:21 +02:00
|
|
|
use crate::common::{shared_does_not_exists_index, Server};
|
2023-09-11 16:50:53 +02:00
|
|
|
use crate::json;
|
2021-02-19 19:26:56 +01:00
|
|
|
|
|
|
|
#[actix_rt::test]
|
|
|
|
async fn create_and_delete_index() {
|
2024-10-01 17:01:47 +02:00
|
|
|
let server = Server::new_shared();
|
|
|
|
let index = server.unique_index();
|
2024-09-29 10:16:31 +02:00
|
|
|
let (response, code) = index.create(None).await;
|
2021-02-19 19:26:56 +01:00
|
|
|
|
2021-12-02 16:03:26 +01:00
|
|
|
assert_eq!(code, 202);
|
|
|
|
|
2024-09-29 10:16:31 +02:00
|
|
|
index.wait_task(response.uid()).await.succeeded();
|
2021-12-02 16:03:26 +01:00
|
|
|
|
|
|
|
assert_eq!(index.get().await.1, 200);
|
2021-02-19 19:26:56 +01:00
|
|
|
|
2024-09-29 10:16:31 +02:00
|
|
|
let (response, code) = index.delete().await;
|
2021-02-19 19:26:56 +01:00
|
|
|
|
2021-12-02 16:03:26 +01:00
|
|
|
assert_eq!(code, 202);
|
|
|
|
|
2024-09-29 10:16:31 +02:00
|
|
|
index.wait_task(response.uid()).await.succeeded();
|
2021-02-19 19:26:56 +01:00
|
|
|
|
2021-06-15 22:21:52 +02:00
|
|
|
assert_eq!(index.get().await.1, 404);
|
2021-02-19 19:26:56 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
#[actix_rt::test]
|
2021-10-21 14:42:01 +02:00
|
|
|
async fn error_delete_unexisting_index() {
|
2024-10-02 16:23:21 +02:00
|
|
|
let index = shared_does_not_exists_index().await;
|
|
|
|
let (task, code) = index.delete_index_fail().await;
|
2021-12-02 16:03:26 +01:00
|
|
|
|
|
|
|
assert_eq!(code, 202);
|
2021-10-21 14:42:01 +02:00
|
|
|
|
|
|
|
let expected_response = json!({
|
2024-10-02 16:23:21 +02:00
|
|
|
"message": "Index `DOES_NOT_EXISTS` not found.",
|
2021-10-21 14:42:01 +02:00
|
|
|
"code": "index_not_found",
|
|
|
|
"type": "invalid_request",
|
2023-01-19 16:10:05 +01:00
|
|
|
"link": "https://docs.meilisearch.com/errors#index_not_found"
|
2021-10-21 14:42:01 +02:00
|
|
|
});
|
2021-02-19 19:26:56 +01:00
|
|
|
|
2024-09-29 10:16:31 +02:00
|
|
|
let response = index.wait_task(task.uid()).await;
|
2021-12-02 16:03:26 +01:00
|
|
|
assert_eq!(response["status"], "failed");
|
|
|
|
assert_eq!(response["error"], expected_response);
|
2021-02-19 19:26:56 +01:00
|
|
|
}
|
2021-07-05 10:02:49 +02:00
|
|
|
|
|
|
|
#[actix_rt::test]
|
|
|
|
async fn loop_delete_add_documents() {
|
2024-10-01 17:01:47 +02:00
|
|
|
let server = Server::new_shared();
|
|
|
|
let index = server.unique_index();
|
2021-07-05 10:02:49 +02:00
|
|
|
let documents = json!([{"id": 1, "field1": "hello"}]);
|
2021-12-02 16:03:26 +01:00
|
|
|
let mut tasks = Vec::new();
|
2021-07-05 10:02:49 +02:00
|
|
|
for _ in 0..50 {
|
|
|
|
let (response, code) = index.add_documents(documents.clone(), None).await;
|
2022-05-17 11:17:32 +02:00
|
|
|
tasks.push(response["taskUid"].as_u64().unwrap());
|
2021-07-05 10:02:49 +02:00
|
|
|
assert_eq!(code, 202, "{}", response);
|
|
|
|
let (response, code) = index.delete().await;
|
2022-05-17 11:17:32 +02:00
|
|
|
tasks.push(response["taskUid"].as_u64().unwrap());
|
2021-12-02 16:03:26 +01:00
|
|
|
assert_eq!(code, 202, "{}", response);
|
|
|
|
}
|
|
|
|
|
|
|
|
for task in tasks {
|
|
|
|
let response = index.wait_task(task).await;
|
|
|
|
assert_eq!(response["status"], "succeeded", "{}", response);
|
2021-07-05 10:02:49 +02:00
|
|
|
}
|
|
|
|
}
|