2022-06-08 08:01:44 +00:00
|
|
|
use crate::*;
|
|
|
|
|
|
|
|
fn test_suite(db: Db) {
|
|
|
|
let tree = db.open_tree("tree").unwrap();
|
|
|
|
|
|
|
|
let ka: &[u8] = &b"test"[..];
|
|
|
|
let kb: &[u8] = &b"zwello"[..];
|
|
|
|
let kint: &[u8] = &b"tz"[..];
|
|
|
|
let va: &[u8] = &b"plop"[..];
|
|
|
|
let vb: &[u8] = &b"plip"[..];
|
|
|
|
let vc: &[u8] = &b"plup"[..];
|
|
|
|
|
2024-03-08 15:38:01 +00:00
|
|
|
// ---- test simple insert/delete ----
|
|
|
|
|
2022-06-08 08:01:44 +00:00
|
|
|
assert!(tree.insert(ka, va).unwrap().is_none());
|
|
|
|
assert_eq!(tree.get(ka).unwrap().unwrap(), va);
|
2024-03-08 15:38:01 +00:00
|
|
|
assert_eq!(tree.len().unwrap(), 1);
|
|
|
|
|
|
|
|
// ---- test transaction logic ----
|
2022-06-08 08:01:44 +00:00
|
|
|
|
2023-09-21 13:32:25 +00:00
|
|
|
let res = db.transaction::<_, (), _>(|tx| {
|
2022-06-08 08:01:44 +00:00
|
|
|
assert_eq!(tx.get(&tree, ka).unwrap().unwrap(), va);
|
|
|
|
|
|
|
|
assert_eq!(tx.insert(&tree, ka, vb).unwrap().unwrap(), va);
|
|
|
|
|
|
|
|
assert_eq!(tx.get(&tree, ka).unwrap().unwrap(), vb);
|
|
|
|
|
2023-09-21 13:32:25 +00:00
|
|
|
Ok(12)
|
2022-06-08 08:01:44 +00:00
|
|
|
});
|
|
|
|
assert!(matches!(res, Ok(12)));
|
|
|
|
assert_eq!(tree.get(ka).unwrap().unwrap(), vb);
|
|
|
|
|
2023-09-21 13:32:25 +00:00
|
|
|
let res = db.transaction::<(), _, _>(|tx| {
|
2022-06-08 08:01:44 +00:00
|
|
|
assert_eq!(tx.get(&tree, ka).unwrap().unwrap(), vb);
|
|
|
|
|
|
|
|
assert_eq!(tx.insert(&tree, ka, vc).unwrap().unwrap(), vb);
|
|
|
|
|
|
|
|
assert_eq!(tx.get(&tree, ka).unwrap().unwrap(), vc);
|
|
|
|
|
2023-09-21 13:32:25 +00:00
|
|
|
Err(TxError::Abort(42))
|
2022-06-08 08:01:44 +00:00
|
|
|
});
|
|
|
|
assert!(matches!(res, Err(TxError::Abort(42))));
|
|
|
|
assert_eq!(tree.get(ka).unwrap().unwrap(), vb);
|
|
|
|
|
2024-03-08 15:38:01 +00:00
|
|
|
// ---- test iteration outside of transactions ----
|
|
|
|
|
2022-06-08 08:01:44 +00:00
|
|
|
let mut iter = tree.iter().unwrap();
|
|
|
|
let next = iter.next().unwrap().unwrap();
|
|
|
|
assert_eq!((next.0.as_ref(), next.1.as_ref()), (ka, vb));
|
|
|
|
assert!(iter.next().is_none());
|
|
|
|
drop(iter);
|
|
|
|
|
|
|
|
assert!(tree.insert(kb, vc).unwrap().is_none());
|
|
|
|
assert_eq!(tree.get(kb).unwrap().unwrap(), vc);
|
|
|
|
|
|
|
|
let mut iter = tree.iter().unwrap();
|
|
|
|
let next = iter.next().unwrap().unwrap();
|
|
|
|
assert_eq!((next.0.as_ref(), next.1.as_ref()), (ka, vb));
|
|
|
|
let next = iter.next().unwrap().unwrap();
|
|
|
|
assert_eq!((next.0.as_ref(), next.1.as_ref()), (kb, vc));
|
|
|
|
assert!(iter.next().is_none());
|
|
|
|
drop(iter);
|
|
|
|
|
|
|
|
let mut iter = tree.range(kint..).unwrap();
|
|
|
|
let next = iter.next().unwrap().unwrap();
|
|
|
|
assert_eq!((next.0.as_ref(), next.1.as_ref()), (kb, vc));
|
|
|
|
assert!(iter.next().is_none());
|
|
|
|
drop(iter);
|
|
|
|
|
|
|
|
let mut iter = tree.range_rev(..kint).unwrap();
|
|
|
|
let next = iter.next().unwrap().unwrap();
|
|
|
|
assert_eq!((next.0.as_ref(), next.1.as_ref()), (ka, vb));
|
|
|
|
assert!(iter.next().is_none());
|
|
|
|
drop(iter);
|
|
|
|
|
|
|
|
let mut iter = tree.iter_rev().unwrap();
|
|
|
|
let next = iter.next().unwrap().unwrap();
|
|
|
|
assert_eq!((next.0.as_ref(), next.1.as_ref()), (kb, vc));
|
|
|
|
let next = iter.next().unwrap().unwrap();
|
|
|
|
assert_eq!((next.0.as_ref(), next.1.as_ref()), (ka, vb));
|
|
|
|
assert!(iter.next().is_none());
|
|
|
|
drop(iter);
|
2024-03-08 15:38:01 +00:00
|
|
|
|
|
|
|
// ---- test iteration within transactions ----
|
|
|
|
|
|
|
|
db.transaction::<_, (), _>(|tx| {
|
|
|
|
let mut iter = tx.iter(&tree).unwrap();
|
|
|
|
let next = iter.next().unwrap().unwrap();
|
|
|
|
assert_eq!((next.0.as_ref(), next.1.as_ref()), (ka, vb));
|
|
|
|
let next = iter.next().unwrap().unwrap();
|
|
|
|
assert_eq!((next.0.as_ref(), next.1.as_ref()), (kb, vc));
|
|
|
|
assert!(iter.next().is_none());
|
|
|
|
Ok(())
|
|
|
|
})
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
db.transaction::<_, (), _>(|tx| {
|
|
|
|
let mut iter = tx.range(&tree, kint..).unwrap();
|
|
|
|
let next = iter.next().unwrap().unwrap();
|
|
|
|
assert_eq!((next.0.as_ref(), next.1.as_ref()), (kb, vc));
|
|
|
|
assert!(iter.next().is_none());
|
|
|
|
Ok(())
|
|
|
|
})
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
db.transaction::<_, (), _>(|tx| {
|
|
|
|
let mut iter = tx.range_rev(&tree, ..kint).unwrap();
|
|
|
|
let next = iter.next().unwrap().unwrap();
|
|
|
|
assert_eq!((next.0.as_ref(), next.1.as_ref()), (ka, vb));
|
|
|
|
assert!(iter.next().is_none());
|
|
|
|
Ok(())
|
|
|
|
})
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
db.transaction::<_, (), _>(|tx| {
|
|
|
|
let mut iter = tx.iter_rev(&tree).unwrap();
|
|
|
|
let next = iter.next().unwrap().unwrap();
|
|
|
|
assert_eq!((next.0.as_ref(), next.1.as_ref()), (kb, vc));
|
|
|
|
let next = iter.next().unwrap().unwrap();
|
|
|
|
assert_eq!((next.0.as_ref(), next.1.as_ref()), (ka, vb));
|
|
|
|
assert!(iter.next().is_none());
|
|
|
|
Ok(())
|
|
|
|
})
|
|
|
|
.unwrap();
|
2022-06-08 08:01:44 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2022-10-14 16:27:18 +00:00
|
|
|
#[cfg(feature = "lmdb")]
|
2022-06-08 08:01:44 +00:00
|
|
|
fn test_lmdb_db() {
|
2022-10-14 16:27:18 +00:00
|
|
|
use crate::lmdb_adapter::LmdbDb;
|
|
|
|
|
2022-06-08 08:01:44 +00:00
|
|
|
let path = mktemp::Temp::new_dir().unwrap();
|
|
|
|
let db = heed::EnvOpenOptions::new()
|
|
|
|
.max_dbs(100)
|
|
|
|
.open(&path)
|
|
|
|
.unwrap();
|
|
|
|
let db = LmdbDb::init(db);
|
|
|
|
test_suite(db);
|
|
|
|
drop(path);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
2022-10-14 16:27:18 +00:00
|
|
|
#[cfg(feature = "sqlite")]
|
2022-06-08 08:01:44 +00:00
|
|
|
fn test_sqlite_db() {
|
2022-10-14 16:27:18 +00:00
|
|
|
use crate::sqlite_adapter::SqliteDb;
|
|
|
|
|
2022-06-08 08:01:44 +00:00
|
|
|
let db = SqliteDb::init(rusqlite::Connection::open_in_memory().unwrap());
|
|
|
|
test_suite(db);
|
|
|
|
}
|