mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-26 05:26:27 +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 crossbeam_channel::Receiver; | ||||||
| use heed::types::{Str, Unit}; | use heed::types::{Str, Unit}; | ||||||
| use heed::{CompactionOption, Result as ZResult}; | use heed::{CompactionOption, Result as ZResult}; | ||||||
| use log::{debug, error}; | use log::debug; | ||||||
|  |  | ||||||
| use crate::{store, update, Index, MResult}; | use crate::{store, update, Index, MResult}; | ||||||
|  |  | ||||||
| @@ -222,3 +222,141 @@ impl Database { | |||||||
|         self.common_store |         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