btree-store 0.1.7

A persistent, embedded key-value storage engine in Rust featuring a Copy-On-Write (COW) B-Tree, ACID compliance, and crash safety with multi-bucket support
Documentation
use btree_store::BTree;
use std::fs;
use tempfile::TempDir;

#[test]
fn test_reuse_within_txn() {
    let temp_dir = TempDir::new().unwrap();
    let db_path = temp_dir.path().join("reuse_txn.db");

    let tree = BTree::open(&db_path).unwrap();
    tree.exec("default", |txn| {
        txn.put(b"large1", vec![0u8; 12000]).unwrap();
        let size_after_put = fs::metadata(&db_path).unwrap().len();
        txn.del(b"large1").unwrap();
        txn.put(b"large2", vec![0u8; 12000]).unwrap();
        let size_after_reuse = fs::metadata(&db_path).unwrap().len();
        assert_eq!(size_after_reuse, size_after_put);
        Ok(())
    })
    .unwrap();
}

#[test]
fn test_reuse_after_reopen() {
    let temp_dir = TempDir::new().unwrap();
    let db_path = temp_dir.path().join("reuse_reopen.db");

    {
        let bt = BTree::open(&db_path).unwrap();
        bt.exec("default", |txn| {
            txn.put(b"large", vec![0u8; 10000]).unwrap();
            Ok(())
        })
        .unwrap();
        bt.exec("default", |txn| {
            txn.del(b"large").unwrap();
            Ok(())
        })
        .unwrap();
        bt.exec("default", |txn| {
            txn.put(b"dummy", b"v").unwrap();
            Ok(())
        })
        .unwrap();
    }

    {
        let bt = BTree::open(&db_path).unwrap();
        bt.exec("default", |txn| {
            txn.put(b"large2", vec![0u8; 10000]).unwrap();
            Ok(())
        })
        .unwrap();
    }

    {
        let bt = BTree::open(&db_path).unwrap();
        bt.view("default", |txn| {
            assert!(txn.get(b"large").is_err());
            assert_eq!(txn.get(b"dummy").unwrap(), b"v");
            Ok(())
        })
        .unwrap();
    }
}

#[test]
fn test_empty_tree_cycle() {
    let temp_dir = TempDir::new().unwrap();
    let db_path = temp_dir.path().join("empty_cycle.db");

    {
        let bt = BTree::open(&db_path).unwrap();
        bt.exec("default", |txn| {
            txn.put(b"k1", b"v1").unwrap();
            txn.put(b"k2", b"v2").unwrap();
            Ok(())
        })
        .unwrap();

        bt.exec("default", |txn| {
            txn.del(b"k1").unwrap();
            txn.del(b"k2").unwrap();
            Ok(())
        })
        .unwrap();
    }

    {
        let bt = BTree::open(&db_path).unwrap();
        bt.view("default", |txn| {
            assert!(txn.get(b"k1").is_err());
            assert!(txn.get(b"k2").is_err());
            Ok(())
        })
        .unwrap();

        bt.exec("default", |txn| {
            txn.put(b"k3", b"v3").unwrap();
            Ok(())
        })
        .unwrap();
    }

    {
        let bt = BTree::open(&db_path).unwrap();
        bt.view("default", |txn| {
            assert_eq!(txn.get(b"k3").unwrap(), b"v3");
            Ok(())
        })
        .unwrap();
    }
}