cesiumdb 0.1.0

Blazing fast, persistent key-value store for Rust
use std::sync::{
    Arc,
    Mutex,
};

use cesiumdb::{
    Db,
    DbOptions,
};
use stability_framework::{
    ShadowVerifier,
    StabilityConfig,
    run_stability_test,
};
use tempfile::TempDir;

mod stability_framework;

#[test]
fn stability_mixed_debug_compact_end() {
    let temp_dir = TempDir::new().unwrap();
    let mut opts = DbOptions::default();
    opts.data_dir(temp_dir.path().to_path_buf());

    let db = Db::open(opts);
    let verifier = Arc::new(Mutex::new(ShadowVerifier::new()));

    let config = StabilityConfig {
        duration_secs: 60,
        num_writers: 4,
        num_readers: 4,
        num_scanners: 0,
        key_space: 500_000,
        value_size: 1024,
        write_rate_hz: 1500,
        verification_interval_ms: 1000,
        delete_probability: 0.1,
    };

    let metrics = run_stability_test(db.clone(), verifier.clone(), config);

    println!("Results:");
    println!("  Writes: {}", metrics.total_writes);
    println!("  Reads: {}", metrics.total_reads);
    println!("  Deletes: {}", metrics.total_deletes);
    println!("  Verification passes: {}", metrics.verification_passes);
    println!("  Verification failures: {}", metrics.verification_failures);
    if let Some(space_amp) = metrics.space_amp {
        println!("  Space amp before compact: {:.2}x", space_amp);
    }

    // Full compaction after test
    println!("Running full compaction...");
    db.compact().unwrap();
    db.sync().unwrap();

    let mut v = verifier.lock().unwrap();
    println!(
        "After compact+sync - errors before final verify: {:?}",
        v.errors
    );
    v.errors.clear();

    let sample_count = 500_000usize / 100;
    let sample_ok = v.verify_random_sample(&db, sample_count);
    let deletes_ok = v.verify_deletes(&db);

    println!("Final sample verification: {}", sample_ok);
    println!("Final delete verification: {}", deletes_ok);
    println!("Final errors: {:?}", v.errors);

    assert!(
        sample_ok,
        "Final sample verification failed: {:?}",
        v.errors
    );
    assert!(
        deletes_ok,
        "Final delete verification failed: {:?}",
        v.errors
    );
    assert!(v.is_clean(), "Shadow verifier has errors: {:?}", v.errors);
}