mirror of
https://github.com/meilisearch/MeiliSearch
synced 2025-01-25 12:47:28 +01:00
b75f1f4c17
# Conflicts: # crates/index-scheduler/src/batch.rs # crates/index-scheduler/src/snapshots/lib.rs/fail_in_process_batch_for_document_deletion/after_removing_the_documents.snap # crates/index-scheduler/src/snapshots/lib.rs/test_document_addition_with_bad_primary_key/fifth_task_succeeds.snap # crates/index-scheduler/src/snapshots/lib.rs/test_document_addition_with_bad_primary_key/fourth_task_fails.snap # crates/index-scheduler/src/snapshots/lib.rs/test_document_addition_with_multiple_primary_key/second_task_fails.snap # crates/index-scheduler/src/snapshots/lib.rs/test_document_addition_with_multiple_primary_key/third_task_fails.snap # crates/index-scheduler/src/snapshots/lib.rs/test_document_addition_with_multiple_primary_key_batch_wrong_key/second_and_third_tasks_fails.snap # crates/index-scheduler/src/snapshots/lib.rs/test_document_addition_with_set_and_null_primary_key_inference_works/all_other_tasks_succeeds.snap # crates/index-scheduler/src/snapshots/lib.rs/test_document_addition_with_set_and_null_primary_key_inference_works/second_task_fails.snap # crates/index-scheduler/src/snapshots/lib.rs/test_document_addition_with_set_and_null_primary_key_inference_works/third_task_succeeds.snap # Conflicts: # crates/index-scheduler/src/batch.rs # crates/meilisearch/src/search/mod.rs # crates/meilisearch/tests/vector/mod.rs # Conflicts: # crates/index-scheduler/src/batch.rs
125 lines
3.3 KiB
Rust
125 lines
3.3 KiB
Rust
use time::format_description::well_known::Rfc3339;
|
|
use time::OffsetDateTime;
|
|
|
|
use crate::common::encoder::Encoder;
|
|
use crate::common::Server;
|
|
use crate::json;
|
|
|
|
#[actix_rt::test]
|
|
async fn update_primary_key() {
|
|
let server = Server::new().await;
|
|
let index = server.index("test");
|
|
let (_, code) = index.create(None).await;
|
|
|
|
assert_eq!(code, 202);
|
|
|
|
index.update(Some("primary")).await;
|
|
|
|
let response = index.wait_task(1).await;
|
|
|
|
assert_eq!(response["status"], "succeeded");
|
|
|
|
let (response, code) = index.get().await;
|
|
|
|
assert_eq!(code, 200);
|
|
|
|
assert_eq!(response["uid"], "test");
|
|
assert!(response.get("createdAt").is_some());
|
|
assert!(response.get("updatedAt").is_some());
|
|
|
|
let created_at =
|
|
OffsetDateTime::parse(response["createdAt"].as_str().unwrap(), &Rfc3339).unwrap();
|
|
let updated_at =
|
|
OffsetDateTime::parse(response["updatedAt"].as_str().unwrap(), &Rfc3339).unwrap();
|
|
assert!(created_at < updated_at);
|
|
|
|
assert_eq!(response["primaryKey"], "primary");
|
|
assert_eq!(response.as_object().unwrap().len(), 4);
|
|
}
|
|
|
|
#[actix_rt::test]
|
|
async fn create_and_update_with_different_encoding() {
|
|
let server = Server::new().await;
|
|
let index = server.index_with_encoder("test", Encoder::Gzip);
|
|
let (_, code) = index.create(None).await;
|
|
|
|
assert_eq!(code, 202);
|
|
|
|
let index = server.index_with_encoder("test", Encoder::Brotli);
|
|
index.update(Some("primary")).await;
|
|
|
|
let response = index.wait_task(1).await;
|
|
|
|
assert_eq!(response["status"], "succeeded");
|
|
}
|
|
|
|
#[actix_rt::test]
|
|
async fn update_nothing() {
|
|
let server = Server::new().await;
|
|
let index = server.index("test");
|
|
let (_, code) = index.create(None).await;
|
|
|
|
assert_eq!(code, 202);
|
|
|
|
index.wait_task(0).await;
|
|
|
|
let (_, code) = index.update(None).await;
|
|
|
|
assert_eq!(code, 202);
|
|
|
|
let response = index.wait_task(1).await;
|
|
|
|
assert_eq!(response["status"], "succeeded");
|
|
}
|
|
|
|
#[actix_rt::test]
|
|
async fn error_update_existing_primary_key() {
|
|
let server = Server::new().await;
|
|
let index = server.index("test");
|
|
let (_response, code) = index.create(Some("id")).await;
|
|
|
|
assert_eq!(code, 202);
|
|
|
|
let documents = json!([
|
|
{
|
|
"id": "11",
|
|
"content": "foobar"
|
|
}
|
|
]);
|
|
index.add_documents(documents, None).await;
|
|
|
|
let (_, code) = index.update(Some("primary")).await;
|
|
|
|
assert_eq!(code, 202);
|
|
|
|
let response = index.wait_task(2).await;
|
|
|
|
let expected_response = json!({
|
|
"message": "Index `test`: Index already has a primary key: `id`.",
|
|
"code": "index_primary_key_already_exists",
|
|
"type": "invalid_request",
|
|
"link": "https://docs.meilisearch.com/errors#index_primary_key_already_exists"
|
|
});
|
|
|
|
assert_eq!(response["error"], expected_response);
|
|
}
|
|
|
|
#[actix_rt::test]
|
|
async fn error_update_unexisting_index() {
|
|
let server = Server::new().await;
|
|
let (_, code) = server.index("test").update(None).await;
|
|
|
|
assert_eq!(code, 202);
|
|
|
|
let response = server.index("test").wait_task(0).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!(response["error"], expected_response);
|
|
}
|