2021-02-22 23:03:17 +08:00
|
|
|
use serde_json::json;
|
|
|
|
|
2021-03-16 01:11:10 +08:00
|
|
|
use crate::common::{GetAllDocumentsOptions, Server};
|
2021-02-22 23:03:17 +08:00
|
|
|
|
|
|
|
#[actix_rt::test]
|
|
|
|
async fn delete_one_document_unexisting_index() {
|
|
|
|
let server = Server::new().await;
|
|
|
|
let (_response, code) = server.index("test").delete_document(0).await;
|
|
|
|
assert_eq!(code, 400);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[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;
|
2021-03-17 20:54:17 +08:00
|
|
|
assert_eq!(code, 202);
|
2021-02-22 23:03:17 +08:00
|
|
|
let update = index.wait_update_id(0).await;
|
|
|
|
assert_eq!(update["status"], "processed");
|
|
|
|
}
|
|
|
|
|
|
|
|
#[actix_rt::test]
|
|
|
|
async fn delete_one_document() {
|
|
|
|
let server = Server::new().await;
|
|
|
|
let index = server.index("test");
|
2021-03-16 01:11:10 +08:00
|
|
|
index
|
|
|
|
.add_documents(json!([{ "id": 0, "content": "foobar" }]), None)
|
|
|
|
.await;
|
2021-02-22 23:03:17 +08:00
|
|
|
index.wait_update_id(0).await;
|
|
|
|
let (_response, code) = server.index("test").delete_document(0).await;
|
2021-03-17 20:54:17 +08:00
|
|
|
assert_eq!(code, 202);
|
2021-02-23 21:13:43 +08:00
|
|
|
index.wait_update_id(1).await;
|
2021-02-22 23:03:17 +08:00
|
|
|
|
|
|
|
let (_response, code) = index.get_document(0, None).await;
|
|
|
|
assert_eq!(code, 400);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[actix_rt::test]
|
|
|
|
async fn clear_all_documents_unexisting_index() {
|
|
|
|
let server = Server::new().await;
|
|
|
|
let (_response, code) = server.index("test").clear_all_documents().await;
|
|
|
|
assert_eq!(code, 400);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[actix_rt::test]
|
|
|
|
async fn clear_all_documents() {
|
|
|
|
let server = Server::new().await;
|
|
|
|
let index = server.index("test");
|
2021-03-16 01:11:10 +08:00
|
|
|
index
|
|
|
|
.add_documents(
|
|
|
|
json!([{ "id": 1, "content": "foobar" }, { "id": 0, "content": "foobar" }]),
|
|
|
|
None,
|
|
|
|
)
|
|
|
|
.await;
|
2021-02-22 23:03:17 +08:00
|
|
|
index.wait_update_id(0).await;
|
|
|
|
let (_response, code) = index.clear_all_documents().await;
|
2021-03-17 20:54:17 +08:00
|
|
|
assert_eq!(code, 202);
|
2021-02-22 23:03:17 +08:00
|
|
|
|
2021-02-23 21:13:43 +08:00
|
|
|
let _update = index.wait_update_id(1).await;
|
2021-03-16 01:11:10 +08:00
|
|
|
let (response, code) = index
|
|
|
|
.get_all_documents(GetAllDocumentsOptions::default())
|
|
|
|
.await;
|
2021-02-22 23:03:17 +08:00
|
|
|
assert_eq!(code, 200);
|
|
|
|
assert!(response.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");
|
|
|
|
index.create(None).await;
|
|
|
|
|
|
|
|
let (_response, code) = index.clear_all_documents().await;
|
2021-03-17 20:54:17 +08:00
|
|
|
assert_eq!(code, 202);
|
2021-02-22 23:03:17 +08:00
|
|
|
|
|
|
|
let _update = index.wait_update_id(0).await;
|
2021-03-16 01:11:10 +08:00
|
|
|
let (response, code) = index
|
|
|
|
.get_all_documents(GetAllDocumentsOptions::default())
|
|
|
|
.await;
|
2021-02-22 23:03:17 +08:00
|
|
|
assert_eq!(code, 200);
|
|
|
|
assert!(response.as_array().unwrap().is_empty());
|
|
|
|
}
|
2021-02-23 21:13:43 +08:00
|
|
|
|
|
|
|
#[actix_rt::test]
|
|
|
|
async fn delete_batch_unexisting_index() {
|
|
|
|
let server = Server::new().await;
|
|
|
|
let (_response, code) = server.index("test").delete_batch(vec![]).await;
|
|
|
|
assert_eq!(code, 400);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[actix_rt::test]
|
|
|
|
async fn delete_batch() {
|
|
|
|
let server = Server::new().await;
|
|
|
|
let index = server.index("test");
|
|
|
|
index.add_documents(json!([{ "id": 1, "content": "foobar" }, { "id": 0, "content": "foobar" }, { "id": 3, "content": "foobar" }]), Some("id")).await;
|
|
|
|
index.wait_update_id(0).await;
|
|
|
|
let (_response, code) = index.delete_batch(vec![1, 0]).await;
|
2021-03-17 20:54:17 +08:00
|
|
|
assert_eq!(code, 202);
|
2021-02-23 21:13:43 +08:00
|
|
|
|
|
|
|
let _update = index.wait_update_id(1).await;
|
2021-03-16 01:11:10 +08:00
|
|
|
let (response, code) = index
|
|
|
|
.get_all_documents(GetAllDocumentsOptions::default())
|
|
|
|
.await;
|
2021-02-23 21:13:43 +08:00
|
|
|
assert_eq!(code, 200);
|
|
|
|
assert_eq!(response.as_array().unwrap().len(), 1);
|
|
|
|
assert_eq!(response.as_array().unwrap()[0]["id"], 3);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[actix_rt::test]
|
|
|
|
async fn delete_no_document_batch() {
|
|
|
|
let server = Server::new().await;
|
|
|
|
let index = server.index("test");
|
|
|
|
index.add_documents(json!([{ "id": 1, "content": "foobar" }, { "id": 0, "content": "foobar" }, { "id": 3, "content": "foobar" }]), Some("id")).await;
|
|
|
|
index.wait_update_id(0).await;
|
|
|
|
let (_response, code) = index.delete_batch(vec![]).await;
|
2021-03-17 20:54:17 +08:00
|
|
|
assert_eq!(code, 202);
|
2021-02-23 21:13:43 +08:00
|
|
|
|
|
|
|
let _update = index.wait_update_id(1).await;
|
2021-03-16 01:11:10 +08:00
|
|
|
let (response, code) = index
|
|
|
|
.get_all_documents(GetAllDocumentsOptions::default())
|
|
|
|
.await;
|
2021-02-23 21:13:43 +08:00
|
|
|
assert_eq!(code, 200);
|
|
|
|
assert_eq!(response.as_array().unwrap().len(), 3);
|
|
|
|
}
|