mirror of
https://github.com/meilisearch/MeiliSearch
synced 2025-01-08 20:44:30 +01:00
Join updates threads after dropping the indexes lock and avoid deadlocks
This commit is contained in:
parent
4abea919b2
commit
c1cf67c008
@ -226,9 +226,12 @@ impl Database {
|
|||||||
// and clear all the LMDB dbi
|
// and clear all the LMDB dbi
|
||||||
let mut writer = self.env.write_txn()?;
|
let mut writer = self.env.write_txn()?;
|
||||||
self.indexes_store.delete(&mut writer, &name)?;
|
self.indexes_store.delete(&mut writer, &name)?;
|
||||||
|
|
||||||
store::clear(&mut writer, &index)?;
|
store::clear(&mut writer, &index)?;
|
||||||
writer.commit()?;
|
writer.commit()?;
|
||||||
|
|
||||||
|
drop(indexes_lock);
|
||||||
|
|
||||||
// join the update loop thread to ensure it is stopped
|
// join the update loop thread to ensure it is stopped
|
||||||
handle.join().unwrap();
|
handle.join().unwrap();
|
||||||
|
|
||||||
@ -832,12 +835,71 @@ mod tests {
|
|||||||
fn delete_index() {
|
fn delete_index() {
|
||||||
let dir = tempfile::tempdir().unwrap();
|
let dir = tempfile::tempdir().unwrap();
|
||||||
|
|
||||||
let database = Database::open_or_create(dir.path()).unwrap();
|
let database = Arc::new(Database::open_or_create(dir.path()).unwrap());
|
||||||
let _index = database.create_index("test").unwrap();
|
let env = &database.env;
|
||||||
|
|
||||||
|
let (sender, receiver) = mpsc::sync_channel(100);
|
||||||
|
let db_cloned = database.clone();
|
||||||
|
let update_fn = move |name: &str, update: ProcessedUpdateResult| {
|
||||||
|
// try to open index to trigger a lock
|
||||||
|
let _ = db_cloned.open_index(name);
|
||||||
|
sender.send(update.update_id).unwrap()
|
||||||
|
};
|
||||||
|
|
||||||
|
// create the index
|
||||||
|
let index = database.create_index("test").unwrap();
|
||||||
|
|
||||||
|
database.set_update_callback(Box::new(update_fn));
|
||||||
|
|
||||||
|
let schema = {
|
||||||
|
let data = r#"
|
||||||
|
identifier = "id"
|
||||||
|
|
||||||
|
[attributes."name"]
|
||||||
|
displayed = true
|
||||||
|
indexed = true
|
||||||
|
|
||||||
|
[attributes."description"]
|
||||||
|
displayed = true
|
||||||
|
indexed = true
|
||||||
|
"#;
|
||||||
|
toml::from_str(data).unwrap()
|
||||||
|
};
|
||||||
|
|
||||||
|
// add a schema to the index
|
||||||
|
let mut writer = env.write_txn().unwrap();
|
||||||
|
let _update_id = index.schema_update(&mut writer, schema).unwrap();
|
||||||
|
writer.commit().unwrap();
|
||||||
|
|
||||||
|
// add documents to the index
|
||||||
|
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();
|
||||||
|
writer.commit().unwrap();
|
||||||
|
|
||||||
|
// delete the index
|
||||||
let deleted = database.delete_index("test").unwrap();
|
let deleted = database.delete_index("test").unwrap();
|
||||||
assert!(deleted);
|
assert!(deleted);
|
||||||
|
|
||||||
|
// block until the transaction is processed
|
||||||
|
let _ = receiver.into_iter().find(|id| *id == update_id);
|
||||||
|
|
||||||
let result = database.open_index("test");
|
let result = database.open_index("test");
|
||||||
assert!(result.is_none());
|
assert!(result.is_none());
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user