mirror of
https://github.com/meilisearch/meilisearch.git
synced 2025-01-22 19:13:10 +08:00
36cb09eb25
Move `meilisearch_error` to `meilisearch_types::error` Move `meilisearch_lib::index_resolver::IndexUid` to `meilisearch_types::index_uid` Add a new `InvalidIndexUid` error in `meilisearch_types::index_uid`
114 lines
3.3 KiB
Rust
114 lines
3.3 KiB
Rust
use crate::common::Server;
|
|
use serde_json::{json, Value};
|
|
|
|
#[actix_rt::test]
|
|
async fn create_index_no_primary_key() {
|
|
let server = Server::new().await;
|
|
let index = server.index("test");
|
|
let (response, code) = index.create(None).await;
|
|
|
|
assert_eq!(code, 202);
|
|
|
|
assert_eq!(response["status"], "enqueued");
|
|
|
|
let response = index.wait_task(0).await;
|
|
|
|
assert_eq!(response["status"], "succeeded");
|
|
assert_eq!(response["type"], "indexCreation");
|
|
assert_eq!(response["details"]["primaryKey"], Value::Null);
|
|
}
|
|
|
|
#[actix_rt::test]
|
|
async fn create_index_with_primary_key() {
|
|
let server = Server::new().await;
|
|
let index = server.index("test");
|
|
let (response, code) = index.create(Some("primary")).await;
|
|
|
|
assert_eq!(code, 202);
|
|
|
|
assert_eq!(response["status"], "enqueued");
|
|
|
|
let response = index.wait_task(0).await;
|
|
|
|
assert_eq!(response["status"], "succeeded");
|
|
assert_eq!(response["type"], "indexCreation");
|
|
assert_eq!(response["details"]["primaryKey"], "primary");
|
|
}
|
|
|
|
#[actix_rt::test]
|
|
async fn create_index_with_invalid_primary_key() {
|
|
let document = json!([ { "id": 2, "title": "Pride and Prejudice" } ]);
|
|
|
|
let server = Server::new().await;
|
|
let index = server.index("movies");
|
|
let (_response, code) = index.add_documents(document, Some("title")).await;
|
|
assert_eq!(code, 202);
|
|
|
|
index.wait_task(0).await;
|
|
|
|
let (response, code) = index.get().await;
|
|
assert_eq!(code, 200);
|
|
assert_eq!(response["primaryKey"], Value::Null);
|
|
}
|
|
|
|
#[actix_rt::test]
|
|
async fn test_create_multiple_indexes() {
|
|
let server = Server::new().await;
|
|
let index1 = server.index("test1");
|
|
let index2 = server.index("test2");
|
|
let index3 = server.index("test3");
|
|
let index4 = server.index("test4");
|
|
|
|
index1.create(None).await;
|
|
index2.create(None).await;
|
|
index3.create(None).await;
|
|
|
|
index1.wait_task(0).await;
|
|
index1.wait_task(1).await;
|
|
index1.wait_task(2).await;
|
|
|
|
assert_eq!(index1.get().await.1, 200);
|
|
assert_eq!(index2.get().await.1, 200);
|
|
assert_eq!(index3.get().await.1, 200);
|
|
assert_eq!(index4.get().await.1, 404);
|
|
}
|
|
|
|
#[actix_rt::test]
|
|
async fn error_create_existing_index() {
|
|
let server = Server::new().await;
|
|
let index = server.index("test");
|
|
let (_, code) = index.create(Some("primary")).await;
|
|
|
|
assert_eq!(code, 202);
|
|
|
|
index.create(Some("primary")).await;
|
|
|
|
let response = index.wait_task(1).await;
|
|
|
|
let expected_response = json!({
|
|
"message": "Index `test` already exists.",
|
|
"code": "index_already_exists",
|
|
"type": "invalid_request",
|
|
"link":"https://docs.meilisearch.com/errors#index_already_exists"
|
|
});
|
|
|
|
assert_eq!(response["error"], expected_response);
|
|
}
|
|
|
|
#[actix_rt::test]
|
|
async fn error_create_with_invalid_index_uid() {
|
|
let server = Server::new().await;
|
|
let index = server.index("test test#!");
|
|
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 _.",
|
|
"code": "invalid_index_uid",
|
|
"type": "invalid_request",
|
|
"link": "https://docs.meilisearch.com/errors#invalid_index_uid"
|
|
});
|
|
|
|
assert_eq!(response, expected_response);
|
|
assert_eq!(code, 400);
|
|
}
|