mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-26 05:26:27 +00:00 
			
		
		
		
	Merge #3688
3688: Following release v1.1.1: bring back changes into `main` r=curquiza a=curquiza `@meilisearch/engine-team` ensure the changes we bring to `main` are the ones you want Co-authored-by: Louis Dureuil <louis@meilisearch.com> Co-authored-by: bors[bot] <26634292+bors[bot]@users.noreply.github.com> Co-authored-by: Tamo <tamo@meilisearch.com> Co-authored-by: dureuill <dureuill@users.noreply.github.com>
This commit is contained in:
		| @@ -68,7 +68,7 @@ const DEFAULT_LOG_EVERY_N: usize = 100_000; | ||||
| // The actual size of the virtual address space is computed at startup to determine how many 2TiB indexes can be | ||||
| // opened simultaneously. | ||||
| pub const INDEX_SIZE: u64 = 2 * 1024 * 1024 * 1024 * 1024; // 2 TiB | ||||
| pub const TASK_DB_SIZE: u64 = 10 * 1024 * 1024 * 1024; // 10 GiB | ||||
| pub const TASK_DB_SIZE: u64 = 20 * 1024 * 1024 * 1024; // 20 GiB | ||||
|  | ||||
| #[derive(Debug, Default, Clone, Copy, Serialize, Deserialize)] | ||||
| #[serde(rename_all = "UPPERCASE")] | ||||
|   | ||||
| @@ -1,11 +1,14 @@ | ||||
| mod errors; | ||||
|  | ||||
| use byte_unit::{Byte, ByteUnit}; | ||||
| use meili_snap::insta::assert_json_snapshot; | ||||
| use meili_snap::{json_string, snapshot}; | ||||
| use serde_json::json; | ||||
| use tempfile::TempDir; | ||||
| use time::format_description::well_known::Rfc3339; | ||||
| use time::OffsetDateTime; | ||||
|  | ||||
| use crate::common::Server; | ||||
| use crate::common::{default_settings, Server}; | ||||
|  | ||||
| #[actix_rt::test] | ||||
| async fn error_get_unexisting_task_status() { | ||||
| @@ -1000,3 +1003,117 @@ async fn test_summarized_dump_creation() { | ||||
|     } | ||||
|     "###); | ||||
| } | ||||
|  | ||||
| #[actix_web::test] | ||||
| async fn test_task_queue_is_full() { | ||||
|     let dir = TempDir::new().unwrap(); | ||||
|     let mut options = default_settings(dir.path()); | ||||
|     options.max_task_db_size = Byte::from_unit(500.0, ByteUnit::B).unwrap(); | ||||
|  | ||||
|     let server = Server::new_with_options(options).await.unwrap(); | ||||
|  | ||||
|     // the first task should be enqueued without issue | ||||
|     let (result, code) = server.create_index(json!({ "uid": "doggo" })).await; | ||||
|     snapshot!(code, @"202 Accepted"); | ||||
|     snapshot!(json_string!(result, { ".enqueuedAt" => "[date]" }), @r###" | ||||
|     { | ||||
|       "taskUid": 0, | ||||
|       "indexUid": "doggo", | ||||
|       "status": "enqueued", | ||||
|       "type": "indexCreation", | ||||
|       "enqueuedAt": "[date]" | ||||
|     } | ||||
|     "###); | ||||
|  | ||||
|     loop { | ||||
|         let (res, code) = server.create_index(json!({ "uid": "doggo" })).await; | ||||
|         if code == 422 { | ||||
|             break; | ||||
|         } | ||||
|         if res["taskUid"] == json!(null) { | ||||
|             panic!( | ||||
|                 "Encountered the strange case:\n{}", | ||||
|                 serde_json::to_string_pretty(&res).unwrap() | ||||
|             ); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     let (result, code) = server.create_index(json!({ "uid": "doggo" })).await; | ||||
|     snapshot!(code, @"422 Unprocessable Entity"); | ||||
|     snapshot!(json_string!(result), @r###" | ||||
|     { | ||||
|       "message": "Meilisearch cannot receive write operations because the limit of the task database has been reached. Please delete tasks to continue performing write operations.", | ||||
|       "code": "no_space_left_on_device", | ||||
|       "type": "system", | ||||
|       "link": "https://docs.meilisearch.com/errors#no_space_left_on_device" | ||||
|     } | ||||
|     "###); | ||||
|  | ||||
|     // But we should still be able to register tasks deletion IF they delete something | ||||
|     let (result, code) = server.delete_tasks("uids=*").await; | ||||
|     snapshot!(code, @"200 OK"); | ||||
|     snapshot!(json_string!(result, { ".enqueuedAt" => "[date]", ".taskUid" => "uid" }), @r###" | ||||
|     { | ||||
|       "taskUid": "uid", | ||||
|       "indexUid": null, | ||||
|       "status": "enqueued", | ||||
|       "type": "taskDeletion", | ||||
|       "enqueuedAt": "[date]" | ||||
|     } | ||||
|     "###); | ||||
|  | ||||
|     let result = server.wait_task(result["taskUid"].as_u64().unwrap()).await; | ||||
|     snapshot!(json_string!(result["status"]), @r###""succeeded""###); | ||||
|  | ||||
|     // Now we should be able to register tasks again | ||||
|     let (result, code) = server.create_index(json!({ "uid": "doggo" })).await; | ||||
|     snapshot!(code, @"202 Accepted"); | ||||
|     snapshot!(json_string!(result, { ".enqueuedAt" => "[date]", ".taskUid" => "uid" }), @r###" | ||||
|     { | ||||
|       "taskUid": "uid", | ||||
|       "indexUid": "doggo", | ||||
|       "status": "enqueued", | ||||
|       "type": "indexCreation", | ||||
|       "enqueuedAt": "[date]" | ||||
|     } | ||||
|     "###); | ||||
|  | ||||
|     // we're going to fill up the queue once again | ||||
|     loop { | ||||
|         let (res, code) = server.delete_tasks("uids=0").await; | ||||
|         if code == 422 { | ||||
|             break; | ||||
|         } | ||||
|         if res["taskUid"] == json!(null) { | ||||
|             panic!( | ||||
|                 "Encountered the strange case:\n{}", | ||||
|                 serde_json::to_string_pretty(&res).unwrap() | ||||
|             ); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     // But we should NOT be able to register this task because it doesn't match any tasks | ||||
|     let (result, code) = server.delete_tasks("uids=0").await; | ||||
|     snapshot!(code, @"422 Unprocessable Entity"); | ||||
|     snapshot!(json_string!(result), @r###" | ||||
|     { | ||||
|       "message": "Meilisearch cannot receive write operations because the limit of the task database has been reached. Please delete tasks to continue performing write operations.", | ||||
|       "code": "no_space_left_on_device", | ||||
|       "type": "system", | ||||
|       "link": "https://docs.meilisearch.com/errors#no_space_left_on_device" | ||||
|     } | ||||
|     "###); | ||||
|  | ||||
|     // The deletion still works | ||||
|     let (result, code) = server.delete_tasks("uids=*").await; | ||||
|     snapshot!(code, @"200 OK"); | ||||
|     snapshot!(json_string!(result, { ".enqueuedAt" => "[date]", ".taskUid" => "uid" }), @r###" | ||||
|     { | ||||
|       "taskUid": "uid", | ||||
|       "indexUid": null, | ||||
|       "status": "enqueued", | ||||
|       "type": "taskDeletion", | ||||
|       "enqueuedAt": "[date]" | ||||
|     } | ||||
|     "###); | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user