2021-04-21 13:09:13 +00:00
|
|
|
use write_buffer::{WriteBufferBuilder, WritePayload};
|
2020-05-21 15:09:28 +00:00
|
|
|
|
|
|
|
#[macro_use]
|
|
|
|
mod helpers;
|
|
|
|
use crate::helpers::*;
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
#[allow(clippy::cognitive_complexity)]
|
|
|
|
fn delete_up_to() -> Result {
|
2020-11-05 18:44:36 +00:00
|
|
|
let dir = test_helpers::tmp_dir()?;
|
2020-05-21 15:09:28 +00:00
|
|
|
|
|
|
|
// Set the file rollover size limit low to test interaction with file rollover
|
2021-04-21 13:09:13 +00:00
|
|
|
let builder = WriteBufferBuilder::new(dir.as_ref()).file_rollover_size(100);
|
|
|
|
let mut write_buffer = builder.clone().write_buffer()?;
|
2020-05-21 15:09:28 +00:00
|
|
|
|
|
|
|
create_and_sync_batch!(
|
2021-04-21 13:09:13 +00:00
|
|
|
write_buffer,
|
2020-05-21 15:09:28 +00:00
|
|
|
[
|
2020-09-08 18:12:16 +00:00
|
|
|
"some data within the file limit",
|
|
|
|
"some more data that puts the file over the limit"
|
2020-05-21 15:09:28 +00:00
|
|
|
]
|
|
|
|
);
|
|
|
|
|
2021-04-21 13:09:13 +00:00
|
|
|
// Write one Write Buffer entry, and because the existing file is over the size
|
|
|
|
// limit, this entry should end up in a new Write Buffer file
|
2020-05-21 15:09:28 +00:00
|
|
|
create_and_sync_batch!(
|
2021-04-21 13:09:13 +00:00
|
|
|
write_buffer,
|
|
|
|
["some more data, this should now be rolled over into the next Write Buffer file"]
|
2020-05-21 15:09:28 +00:00
|
|
|
);
|
|
|
|
|
2021-04-21 13:09:13 +00:00
|
|
|
// Write two Write Buffer entries, one that could fit in the existing file but
|
|
|
|
// puts the file over the limit. Because the two entries are in one sync
|
|
|
|
// batch, they both will end up in the existing file even though it's over
|
|
|
|
// the limit after the first entry.
|
2020-05-21 15:09:28 +00:00
|
|
|
create_and_sync_batch!(
|
2021-04-21 13:09:13 +00:00
|
|
|
write_buffer,
|
2020-05-21 15:09:28 +00:00
|
|
|
[
|
2020-09-08 18:12:16 +00:00
|
|
|
"one entry that puts the existing file over the limit",
|
|
|
|
"another entry"
|
2020-05-21 15:09:28 +00:00
|
|
|
]
|
|
|
|
);
|
|
|
|
|
2021-04-21 13:09:13 +00:00
|
|
|
// There should be two existing Write Buffer files
|
2020-05-21 15:09:28 +00:00
|
|
|
assert_filenames_for_sequence_numbers!(dir, [0, 2]);
|
|
|
|
|
|
|
|
// Should be able to read the entries back out
|
2021-04-21 13:09:13 +00:00
|
|
|
let write_buffer_entries = all_entries(&builder)?;
|
|
|
|
assert_eq!(5, write_buffer_entries.len());
|
2020-05-21 15:09:28 +00:00
|
|
|
assert_entry!(
|
2021-04-21 13:09:13 +00:00
|
|
|
write_buffer_entries[0],
|
|
|
|
0,
|
|
|
|
b"some data within the file limit"
|
|
|
|
);
|
|
|
|
assert_entry!(
|
|
|
|
write_buffer_entries[1],
|
2020-05-21 15:09:28 +00:00
|
|
|
1,
|
|
|
|
b"some more data that puts the file over the limit"
|
|
|
|
);
|
|
|
|
assert_entry!(
|
2021-04-21 13:09:13 +00:00
|
|
|
write_buffer_entries[2],
|
2020-05-21 15:09:28 +00:00
|
|
|
2,
|
2021-04-21 13:09:13 +00:00
|
|
|
b"some more data, this should now be rolled over into the next Write Buffer file"
|
2020-05-21 15:09:28 +00:00
|
|
|
);
|
|
|
|
assert_entry!(
|
2021-04-21 13:09:13 +00:00
|
|
|
write_buffer_entries[3],
|
2020-05-21 15:09:28 +00:00
|
|
|
3,
|
|
|
|
b"one entry that puts the existing file over the limit"
|
|
|
|
);
|
2021-04-21 13:09:13 +00:00
|
|
|
assert_entry!(write_buffer_entries[4], 4, b"another entry");
|
2020-05-21 15:09:28 +00:00
|
|
|
|
2020-05-27 13:49:05 +00:00
|
|
|
// Not including 3!
|
2021-04-21 13:09:13 +00:00
|
|
|
write_buffer.delete_up_to_entry(3)?;
|
2020-05-21 15:09:28 +00:00
|
|
|
|
2021-04-21 13:09:13 +00:00
|
|
|
// There should be one existing Write Buffer file
|
2020-05-21 15:09:28 +00:00
|
|
|
assert_filenames_for_sequence_numbers!(dir, [2]);
|
|
|
|
|
|
|
|
// Add another entry; the sequence numbers continue
|
2021-04-21 13:09:13 +00:00
|
|
|
create_and_sync_batch!(write_buffer, ["entry after deletion"]);
|
2020-05-21 15:09:28 +00:00
|
|
|
|
|
|
|
// Should be able to read the entries back out
|
2021-04-21 13:09:13 +00:00
|
|
|
let write_buffer_entries = all_entries(&builder)?;
|
|
|
|
assert_eq!(4, write_buffer_entries.len());
|
2020-05-21 15:09:28 +00:00
|
|
|
|
2020-12-11 18:15:53 +00:00
|
|
|
// 2 is still readable, because we asked to delete it but couldn't because it
|
|
|
|
// was in a file with 3.
|
2020-05-21 15:09:28 +00:00
|
|
|
assert_entry!(
|
2021-04-21 13:09:13 +00:00
|
|
|
write_buffer_entries[0],
|
2020-05-21 15:09:28 +00:00
|
|
|
2,
|
2021-04-21 13:09:13 +00:00
|
|
|
b"some more data, this should now be rolled over into the next Write Buffer file"
|
2020-05-21 15:09:28 +00:00
|
|
|
);
|
|
|
|
assert_entry!(
|
2021-04-21 13:09:13 +00:00
|
|
|
write_buffer_entries[1],
|
2020-05-21 15:09:28 +00:00
|
|
|
3,
|
|
|
|
b"one entry that puts the existing file over the limit"
|
|
|
|
);
|
2021-04-21 13:09:13 +00:00
|
|
|
assert_entry!(write_buffer_entries[2], 4, b"another entry");
|
|
|
|
assert_entry!(write_buffer_entries[3], 5, b"entry after deletion");
|
2020-05-21 15:09:28 +00:00
|
|
|
|
|
|
|
Ok(())
|
|
|
|
}
|