2024-08-30 03:44:34 +00:00
|
|
|
use bytes::Bytes;
|
2024-09-04 13:00:17 +00:00
|
|
|
use loro_kv_store::{mem_store::MemKvConfig, MemKvStore};
|
2024-08-30 03:44:34 +00:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn add_and_remove() {
|
|
|
|
let key = &[0];
|
|
|
|
let value = Bytes::from_static(&[0]);
|
2024-09-04 13:00:17 +00:00
|
|
|
let mut store = MemKvStore::new(MemKvConfig::default());
|
2024-08-30 03:44:34 +00:00
|
|
|
store.set(key, value.clone());
|
|
|
|
assert_eq!(store.get(key), Some(value));
|
|
|
|
store.remove(key);
|
|
|
|
assert_eq!(store.get(key), None);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn add_flush_remove() {
|
|
|
|
let key = &[0];
|
|
|
|
let value = Bytes::from_static(&[0]);
|
2024-09-04 13:00:17 +00:00
|
|
|
let mut store = MemKvStore::new(MemKvConfig::default());
|
2024-08-30 03:44:34 +00:00
|
|
|
store.set(key, value.clone());
|
|
|
|
store.export_all();
|
|
|
|
store.remove(key);
|
|
|
|
assert_eq!(store.get(key), None);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn add_flush_add_scan() {
|
|
|
|
let key1 = &[0];
|
|
|
|
let value1 = Bytes::from_static(&[0]);
|
|
|
|
let key2 = &[128];
|
|
|
|
let value2 = Bytes::from_static(&[252, 169]);
|
2024-09-04 13:00:17 +00:00
|
|
|
let mut store = MemKvStore::new(MemKvConfig::new().should_encode_none(true));
|
2024-08-30 03:44:34 +00:00
|
|
|
store.set(key1, value1.clone());
|
|
|
|
store.export_all();
|
2024-09-11 10:13:41 +00:00
|
|
|
ensure_cov::assert_cov("kv_store::block::NormalBlock::encode::compress_fallback");
|
2024-08-30 03:44:34 +00:00
|
|
|
store.set(key2, value2.clone());
|
2024-09-11 10:13:41 +00:00
|
|
|
{
|
|
|
|
let mut iter = store.scan(std::ops::Bound::Unbounded, std::ops::Bound::Unbounded);
|
|
|
|
assert_eq!(
|
|
|
|
iter.next(),
|
|
|
|
Some((Bytes::from_static(key1), value1.clone()))
|
|
|
|
);
|
|
|
|
assert_eq!(
|
|
|
|
iter.next(),
|
|
|
|
Some((Bytes::from_static(key2), value2.clone()))
|
|
|
|
);
|
|
|
|
assert_eq!(iter.next(), None);
|
|
|
|
|
|
|
|
let mut iter = store
|
|
|
|
.scan(std::ops::Bound::Unbounded, std::ops::Bound::Unbounded)
|
|
|
|
.rev();
|
|
|
|
assert_eq!(
|
|
|
|
iter.next(),
|
|
|
|
Some((Bytes::from_static(key2), value2.clone()))
|
|
|
|
);
|
|
|
|
assert_eq!(
|
|
|
|
iter.next(),
|
|
|
|
Some((Bytes::from_static(key1), value1.clone()))
|
|
|
|
);
|
|
|
|
assert_eq!(iter.next(), None);
|
|
|
|
}
|
|
|
|
|
|
|
|
let bytes = store.export_all();
|
2024-09-11 15:34:05 +00:00
|
|
|
let mut store = MemKvStore::new(MemKvConfig::new());
|
2024-09-11 10:13:41 +00:00
|
|
|
store.import_all(bytes).unwrap();
|
2024-08-30 03:44:34 +00:00
|
|
|
let mut iter = store.scan(std::ops::Bound::Unbounded, std::ops::Bound::Unbounded);
|
|
|
|
assert_eq!(
|
|
|
|
iter.next(),
|
|
|
|
Some((Bytes::from_static(key1), value1.clone()))
|
|
|
|
);
|
|
|
|
assert_eq!(
|
|
|
|
iter.next(),
|
|
|
|
Some((Bytes::from_static(key2), value2.clone()))
|
|
|
|
);
|
|
|
|
assert_eq!(iter.next(), None);
|
2024-09-11 10:13:41 +00:00
|
|
|
}
|
2024-08-30 03:44:34 +00:00
|
|
|
|
2024-09-11 10:13:41 +00:00
|
|
|
#[test]
|
|
|
|
fn large_value() {
|
|
|
|
use rand::Rng;
|
|
|
|
let key = &[0];
|
|
|
|
let mut rng = rand::thread_rng();
|
|
|
|
let large_value: Vec<u8> = (0..100_000).map(|_| rng.gen()).collect();
|
|
|
|
let large_value = Bytes::from(large_value);
|
|
|
|
|
2024-09-11 15:34:05 +00:00
|
|
|
let mut store = MemKvStore::new(MemKvConfig::new());
|
2024-09-11 10:13:41 +00:00
|
|
|
store.set(key, large_value.clone());
|
|
|
|
|
|
|
|
let bytes = store.export_all();
|
|
|
|
ensure_cov::assert_cov("kv_store::block::LargeValueBlock::encode::compress_fallback");
|
2024-09-11 15:34:05 +00:00
|
|
|
let mut imported_store = MemKvStore::new(MemKvConfig::new());
|
2024-09-11 10:13:41 +00:00
|
|
|
imported_store.import_all(bytes).unwrap();
|
|
|
|
|
|
|
|
let retrieved_value = imported_store.get(key).unwrap();
|
|
|
|
assert_eq!(retrieved_value, large_value);
|
|
|
|
|
|
|
|
let mut iter = imported_store.scan(std::ops::Bound::Unbounded, std::ops::Bound::Unbounded);
|
|
|
|
assert_eq!(iter.next(), Some((Bytes::from_static(key), large_value)));
|
2024-08-30 03:44:34 +00:00
|
|
|
assert_eq!(iter.next(), None);
|
|
|
|
}
|