mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 21:16:28 +00:00 
			
		
		
		
	Add tests to the update system
This commit is contained in:
		| @@ -7,7 +7,7 @@ use std::{fs, thread}; | ||||
| use crossbeam_channel::Receiver; | ||||
| use heed::types::{Str, Unit}; | ||||
| use heed::{CompactionOption, Result as ZResult}; | ||||
| use log::{debug, error}; | ||||
| use log::debug; | ||||
|  | ||||
| use crate::{store, update, Index, MResult}; | ||||
|  | ||||
| @@ -222,3 +222,141 @@ impl Database { | ||||
|         self.common_store | ||||
|     } | ||||
| } | ||||
|  | ||||
| #[cfg(test)] | ||||
| mod tests { | ||||
|     use super::*; | ||||
|     use crate::update::{ProcessedUpdateResult, UpdateStatus}; | ||||
|     use std::sync::mpsc; | ||||
|  | ||||
|     #[test] | ||||
|     fn valid_updates() { | ||||
|         let dir = tempfile::tempdir().unwrap(); | ||||
|  | ||||
|         let database = Database::open_or_create(dir.path()).unwrap(); | ||||
|         let env = &database.env; | ||||
|  | ||||
|         let (sender, receiver) = mpsc::sync_channel(100); | ||||
|         let update_fn = move |update: ProcessedUpdateResult| sender.send(update.update_id).unwrap(); | ||||
|         let index = database.create_index("test").unwrap(); | ||||
|  | ||||
|         let done = database.set_update_callback("test", Box::new(update_fn)); | ||||
|         assert!(done, "could not set the index update function"); | ||||
|  | ||||
|         let schema = { | ||||
|             let data = r#" | ||||
|                 identifier = "id" | ||||
|  | ||||
|                 [attributes."name"] | ||||
|                 displayed = true | ||||
|                 indexed = true | ||||
|  | ||||
|                 [attributes."description"] | ||||
|                 displayed = true | ||||
|                 indexed = true | ||||
|             "#; | ||||
|             toml::from_str(data).unwrap() | ||||
|         }; | ||||
|  | ||||
|         let mut writer = env.write_txn().unwrap(); | ||||
|         let _update_id = index.schema_update(&mut writer, schema).unwrap(); | ||||
|  | ||||
|         // don't forget to commit... | ||||
|         writer.commit().unwrap(); | ||||
|  | ||||
|         let mut additions = index.documents_addition(); | ||||
|  | ||||
|         let doc1 = serde_json::json!({ | ||||
|             "id": 123, | ||||
|             "name": "Marvin", | ||||
|             "description": "My name is Marvin", | ||||
|         }); | ||||
|  | ||||
|         let doc2 = serde_json::json!({ | ||||
|             "id": 234, | ||||
|             "name": "Kevin", | ||||
|             "description": "My name is Kevin", | ||||
|         }); | ||||
|  | ||||
|         additions.update_document(doc1); | ||||
|         additions.update_document(doc2); | ||||
|  | ||||
|         let mut writer = env.write_txn().unwrap(); | ||||
|         let update_id = additions.finalize(&mut writer).unwrap(); | ||||
|  | ||||
|         // don't forget to commit... | ||||
|         writer.commit().unwrap(); | ||||
|  | ||||
|         // block until the transaction is processed | ||||
|         let _ = receiver.into_iter().find(|id| *id == update_id); | ||||
|  | ||||
|         let reader = env.read_txn().unwrap(); | ||||
|         let result = index.update_status(&reader, update_id).unwrap(); | ||||
|         assert_matches!(result, UpdateStatus::Processed(status) if status.result.is_ok()); | ||||
|     } | ||||
|  | ||||
|     #[test] | ||||
|     fn invalid_updates() { | ||||
|         let dir = tempfile::tempdir().unwrap(); | ||||
|  | ||||
|         let database = Database::open_or_create(dir.path()).unwrap(); | ||||
|         let env = &database.env; | ||||
|  | ||||
|         let (sender, receiver) = mpsc::sync_channel(100); | ||||
|         let update_fn = move |update: ProcessedUpdateResult| sender.send(update.update_id).unwrap(); | ||||
|         let index = database.create_index("test").unwrap(); | ||||
|  | ||||
|         let done = database.set_update_callback("test", Box::new(update_fn)); | ||||
|         assert!(done, "could not set the index update function"); | ||||
|  | ||||
|         let schema = { | ||||
|             let data = r#" | ||||
|                 identifier = "id" | ||||
|  | ||||
|                 [attributes."name"] | ||||
|                 displayed = true | ||||
|                 indexed = true | ||||
|  | ||||
|                 [attributes."description"] | ||||
|                 displayed = true | ||||
|                 indexed = true | ||||
|             "#; | ||||
|             toml::from_str(data).unwrap() | ||||
|         }; | ||||
|  | ||||
|         let mut writer = env.write_txn().unwrap(); | ||||
|         let _update_id = index.schema_update(&mut writer, schema).unwrap(); | ||||
|  | ||||
|         // don't forget to commit... | ||||
|         writer.commit().unwrap(); | ||||
|  | ||||
|         let mut additions = index.documents_addition(); | ||||
|  | ||||
|         let doc1 = serde_json::json!({ | ||||
|             "id": 123, | ||||
|             "name": "Marvin", | ||||
|             "description": "My name is Marvin", | ||||
|         }); | ||||
|  | ||||
|         let doc2 = serde_json::json!({ | ||||
|             "name": "Kevin", | ||||
|             "description": "My name is Kevin", | ||||
|         }); | ||||
|  | ||||
|         additions.update_document(doc1); | ||||
|         additions.update_document(doc2); | ||||
|  | ||||
|         let mut writer = env.write_txn().unwrap(); | ||||
|         let update_id = additions.finalize(&mut writer).unwrap(); | ||||
|  | ||||
|         // don't forget to commit... | ||||
|         writer.commit().unwrap(); | ||||
|  | ||||
|         // block until the transaction is processed | ||||
|         let _ = receiver.into_iter().find(|id| *id == update_id); | ||||
|  | ||||
|         let reader = env.read_txn().unwrap(); | ||||
|         let result = index.update_status(&reader, update_id).unwrap(); | ||||
|         assert_matches!(result, UpdateStatus::Processed(status) if status.result.is_err()); | ||||
|     } | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user