From b8e0ba9872d8021cd7b2a9595354b7a18a4c4666 Mon Sep 17 00:00:00 2001 From: Yuya Nishihara Date: Thu, 18 May 2023 19:03:14 +0900 Subject: [PATCH] stacked_table: do not remove head on empty save_table() If the head is unchanged, it shouldn't be removed. Otherwise the next reader wouldn't find the existing table. --- lib/src/stacked_table.rs | 21 ++++++++++++++++++++- 1 file changed, 20 insertions(+), 1 deletion(-) diff --git a/lib/src/stacked_table.rs b/lib/src/stacked_table.rs index 1e6da7c3c4..d4748995c8 100644 --- a/lib/src/stacked_table.rs +++ b/lib/src/stacked_table.rs @@ -409,7 +409,9 @@ impl TableStore { let table = mut_table.save_in(self)?; self.add_head(&table)?; if let Some(parent_table) = maybe_parent_table { - self.remove_head(&parent_table); + if parent_table.name != table.name { + self.remove_head(&parent_table); + } } { let mut locked_cache = self.cached_tables.write().unwrap(); @@ -676,4 +678,21 @@ mod tests { assert_eq!(merged_table.get_value(b"zzz"), Some(b"val3".as_slice())); assert_eq!(merged_table.get_value(b"\xff\xff\xff"), None); } + + #[test] + fn stacked_table_store_save_empty() { + let temp_dir = testutils::new_temp_dir(); + let store = TableStore::init(temp_dir.path().to_path_buf(), 3); + + let mut mut_table = store.get_head().unwrap().start_mutation(); + mut_table.add_entry(b"abc".to_vec(), b"value".to_vec()); + store.save_table(mut_table).unwrap(); + + let mut_table = store.get_head().unwrap().start_mutation(); + store.save_table(mut_table).unwrap(); + + // Table head shouldn't be removed on empty save + let table = store.get_head().unwrap(); + assert_eq!(table.get_value(b"abc"), Some(b"value".as_slice())); + } }