MeiliSearch/meilisearch/tests/index/stats.rs

64 lines
1.6 KiB
Rust
Raw Permalink Normal View History

2021-04-01 20:54:37 +02:00
use serde_json::json;
use crate::common::Server;
#[actix_rt::test]
async fn stats() {
let server = Server::new().await;
let index = server.index("test");
let (_, code) = index.create(Some("id")).await;
assert_eq!(code, 202);
index.wait_task(0).await;
2021-04-01 20:54:37 +02:00
let (response, code) = index.stats().await;
assert_eq!(code, 200);
assert_eq!(response["numberOfDocuments"], 0);
2021-06-17 18:50:18 +02:00
assert!(response["isIndexing"] == false);
2022-10-20 18:00:07 +02:00
assert!(response["fieldDistribution"].as_object().unwrap().is_empty());
2021-04-01 20:54:37 +02:00
let documents = json!([
{
"id": 1,
"name": "Alexey",
},
{
"id": 2,
"age": 45,
}
]);
let (response, code) = index.add_documents(documents, None).await;
assert_eq!(code, 202);
assert_eq!(response["taskUid"], 1);
2021-04-01 20:54:37 +02:00
index.wait_task(1).await;
2021-04-01 20:54:37 +02:00
let (response, code) = index.stats().await;
assert_eq!(code, 200);
assert_eq!(response["numberOfDocuments"], 2);
2021-06-17 18:50:18 +02:00
assert!(response["isIndexing"] == false);
2021-06-21 16:59:27 +02:00
assert_eq!(response["fieldDistribution"]["id"], 2);
assert_eq!(response["fieldDistribution"]["name"], 1);
assert_eq!(response["fieldDistribution"]["age"], 1);
2021-04-01 20:54:37 +02:00
}
2021-10-21 14:42:01 +02:00
#[actix_rt::test]
async fn error_get_stats_unexisting_index() {
let server = Server::new().await;
let (response, code) = server.index("test").stats().await;
let expected_response = json!({
2021-10-26 19:36:48 +02:00
"message": "Index `test` 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
});
assert_eq!(response, expected_response);
assert_eq!(code, 404);
}