[INFO] fetching crate sochdb-storage 2.0.2...
[INFO] checking sochdb-storage-2.0.2 against master#507271bc119683008ec719ecee48814e8ac86c65 for pr-146440
[INFO] extracting crate sochdb-storage 2.0.2 into /workspace/builds/worker-1-tc1/source
[INFO] started tweaking crates.io crate sochdb-storage 2.0.2
[INFO] removed 0 missing tests
[INFO] finished tweaking crates.io crate sochdb-storage 2.0.2
[INFO] tweaked toml for crates.io crate sochdb-storage 2.0.2 written to /workspace/builds/worker-1-tc1/source/Cargo.toml
[INFO] validating manifest of crates.io crate sochdb-storage 2.0.2 on toolchain 507271bc119683008ec719ecee48814e8ac86c65
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+507271bc119683008ec719ecee48814e8ac86c65" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate crates.io crate sochdb-storage 2.0.2 already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+507271bc119683008ec719ecee48814e8ac86c65" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded lz4 v1.28.1
[INFO] [stderr]   Downloaded toon-format v0.4.5
[INFO] [stderr]   Downloaded atoi v2.0.0
[INFO] [stderr]   Downloaded array-init v2.1.0
[INFO] [stderr]   Downloaded tagptr v0.2.0
[INFO] [stderr]   Downloaded flatbuffers v24.12.23
[INFO] [stderr]   Downloaded lexical-core v1.0.6
[INFO] [stderr]   Downloaded aes-gcm-siv v0.11.1
[INFO] [stderr]   Downloaded crossbeam-skiplist v0.1.3
[INFO] [stderr]   Downloaded polyval v0.6.2
[INFO] [stderr]   Downloaded lz4_flex v0.11.6
[INFO] [stderr]   Downloaded arrow-string v54.3.1
[INFO] [stderr]   Downloaded lexical-parse-integer v1.0.6
[INFO] [stderr]   Downloaded arrow-schema v54.3.1
[INFO] [stderr]   Downloaded arrow-ord v54.3.1
[INFO] [stderr]   Downloaded arrow-arith v54.3.1
[INFO] [stderr]   Downloaded arrow-data v54.3.1
[INFO] [stderr]   Downloaded arrow-row v54.3.1
[INFO] [stderr]   Downloaded io-uring v0.6.4
[INFO] [stderr]   Downloaded arrow-buffer v54.3.1
[INFO] [stderr]   Downloaded lexical-write-integer v1.0.6
[INFO] [stderr]   Downloaded arrow-select v54.3.1
[INFO] [stderr]   Downloaded lexical-util v1.0.7
[INFO] [stderr]   Downloaded prometheus v0.14.0
[INFO] [stderr]   Downloaded lexical-write-float v1.0.6
[INFO] [stderr]   Downloaded arrow v54.3.1
[INFO] [stderr]   Downloaded arrow-ipc v54.3.1
[INFO] [stderr]   Downloaded arrow-cast v54.3.1
[INFO] [stderr]   Downloaded sochdb-core v2.0.2
[INFO] [stderr]   Downloaded lexical-parse-float v1.0.6
[INFO] [stderr]   Downloaded blake3 v1.8.4
[INFO] [stderr]   Downloaded moka v0.12.15
[INFO] [stderr]   Downloaded arrow-array v54.3.1
[INFO] [stderr]   Downloaded ndarray v0.15.6
[INFO] [stderr]   Downloaded nix v0.27.1
[INFO] [stderr]   Downloaded sochdb-index v2.0.2
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+507271bc119683008ec719ecee48814e8ac86c65" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 008f2a458d661d3c4da24d617b86c6612f0feb298df54f8f80aafe62db1f4936
[INFO] running `Command { std: "docker" "start" "-a" "008f2a458d661d3c4da24d617b86c6612f0feb298df54f8f80aafe62db1f4936", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "008f2a458d661d3c4da24d617b86c6612f0feb298df54f8f80aafe62db1f4936", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "008f2a458d661d3c4da24d617b86c6612f0feb298df54f8f80aafe62db1f4936", kill_on_drop: false }`
[INFO] [stdout] 008f2a458d661d3c4da24d617b86c6612f0feb298df54f8f80aafe62db1f4936
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+507271bc119683008ec719ecee48814e8ac86c65" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 1c86760a2446503ce483e9a02e640325c8073e28b211c1632302d3d1ffb1b7e0
[INFO] running `Command { std: "docker" "start" "-a" "1c86760a2446503ce483e9a02e640325c8073e28b211c1632302d3d1ffb1b7e0", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.185
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling getrandom v0.3.4
[INFO] [stderr]    Compiling ahash v0.8.12
[INFO] [stderr]    Compiling zerocopy-derive v0.8.48
[INFO] [stderr]     Checking generic-array v0.14.7
[INFO] [stderr]     Checking arrow-schema v54.3.1
[INFO] [stderr]     Checking hashbrown v0.15.5
[INFO] [stderr]     Checking lexical-util v1.0.7
[INFO] [stderr]     Checking crossbeam-epoch v0.9.18
[INFO] [stderr]     Checking smallvec v1.15.1
[INFO] [stderr]    Compiling serde_json v1.0.149
[INFO] [stderr]    Compiling flatbuffers v24.12.23
[INFO] [stderr]     Checking lexical-write-integer v1.0.6
[INFO] [stderr]     Checking lexical-parse-integer v1.0.6
[INFO] [stderr]    Compiling thiserror-impl v2.0.18
[INFO] [stderr]    Compiling zstd-safe v7.2.4
[INFO] [stderr]     Checking lexical-parse-float v1.0.6
[INFO] [stderr]     Checking num-integer v0.1.46
[INFO] [stderr]     Checking num-complex v0.4.6
[INFO] [stderr]     Checking num-bigint v0.4.6
[INFO] [stderr]    Compiling jobserver v0.1.34
[INFO] [stderr]     Checking num-iter v0.1.45
[INFO] [stderr]     Checking chrono v0.4.44
[INFO] [stderr]     Checking lexical-write-float v1.0.6
[INFO] [stderr]    Compiling cc v1.2.60
[INFO] [stderr]     Checking regex v1.12.3
[INFO] [stderr]     Checking zerocopy v0.8.48
[INFO] [stderr]     Checking inout v0.1.4
[INFO] [stderr]     Checking getrandom v0.2.17
[INFO] [stderr]     Checking parking_lot_core v0.9.12
[INFO] [stderr]     Checking getrandom v0.4.2
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking crossbeam-deque v0.8.6
[INFO] [stderr]     Checking parking_lot v0.12.5
[INFO] [stderr]     Checking crypto-common v0.1.7
[INFO] [stderr]     Checking thiserror v2.0.18
[INFO] [stderr]    Compiling matrixmultiply v0.3.10
[INFO] [stderr]    Compiling portable-atomic v1.13.1
[INFO] [stderr]     Checking cipher v0.4.4
[INFO] [stderr]     Checking rayon-core v1.13.0
[INFO] [stderr]     Checking rand_core v0.9.5
[INFO] [stderr]     Checking num-rational v0.4.2
[INFO] [stderr]     Checking lexical-core v1.0.6
[INFO] [stderr]     Checking atoi v2.0.0
[INFO] [stderr]     Checking block-buffer v0.10.4
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]     Checking arrayvec v0.7.6
[INFO] [stderr]     Checking constant_time_eq v0.4.2
[INFO] [stderr]     Checking num v0.4.3
[INFO] [stderr]     Checking simd-adler32 v0.3.9
[INFO] [stderr]     Checking arrayref v0.3.9
[INFO] [stderr]     Checking cpufeatures v0.3.0
[INFO] [stderr]     Checking rawpointer v0.2.1
[INFO] [stderr]    Compiling prometheus v0.14.0
[INFO] [stderr]     Checking dirs-sys v0.4.1
[INFO] [stderr]     Checking miniz_oxide v0.8.9
[INFO] [stderr]     Checking universal-hash v0.5.1
[INFO] [stderr]     Checking dashmap v5.5.3
[INFO] [stderr]     Checking tempfile v3.27.0
[INFO] [stderr]     Checking digest v0.10.7
[INFO] [stderr]     Checking rayon v1.12.0
[INFO] [stderr]     Checking toon-format v0.4.5
[INFO] [stderr]     Checking uuid v1.23.1
[INFO] [stderr]     Checking bincode v1.3.3
[INFO] [stderr]    Compiling zstd-sys v2.0.16+zstd.1.5.7
[INFO] [stderr]    Compiling lz4-sys v1.11.1+lz4-1.10.0
[INFO] [stderr]    Compiling blake3 v1.8.4
[INFO] [stderr]    Compiling zeroize_derive v1.4.3
[INFO] [stderr]    Compiling io-uring v0.6.4
[INFO] [stderr]     Checking tagptr v0.2.0
[INFO] [stderr]     Checking thiserror v1.0.69
[INFO] [stderr]     Checking polyval v0.6.2
[INFO] [stderr]     Checking moka v0.12.15
[INFO] [stderr]     Checking clap_builder v4.6.0
[INFO] [stderr]     Checking zeroize v1.8.2
[INFO] [stderr]     Checking flate2 v1.1.9
[INFO] [stderr]     Checking ndarray v0.15.6
[INFO] [stderr]     Checking sha2 v0.10.9
[INFO] [stderr]     Checking dirs v5.0.1
[INFO] [stderr]     Checking ctr v0.9.2
[INFO] [stderr]     Checking aes v0.8.4
[INFO] [stderr]     Checking aead v0.5.2
[INFO] [stderr]     Checking wait-timeout v0.2.1
[INFO] [stderr]     Checking memmap2 v0.9.10
[INFO] [stderr]     Checking ordered-float v4.6.0
[INFO] [stderr]     Checking array-init v2.1.0
[INFO] [stderr]     Checking twox-hash v2.1.2
[INFO] [stderr]     Checking bit-vec v0.8.0
[INFO] [stderr]     Checking aes-gcm-siv v0.11.1
[INFO] [stderr]     Checking lz4_flex v0.11.6
[INFO] [stderr]     Checking rusty-fork v0.3.1
[INFO] [stderr]     Checking bit-set v0.8.0
[INFO] [stderr]     Checking clap v4.6.1
[INFO] [stderr]     Checking arc-swap v1.9.1
[INFO] [stderr]     Checking plotters v0.3.7
[INFO] [stderr]     Checking rand v0.9.4
[INFO] [stderr]     Checking rand_xorshift v0.4.0
[INFO] [stderr]     Checking is-terminal v0.4.17
[INFO] [stderr]     Checking num_cpus v1.17.0
[INFO] [stderr]     Checking nix v0.27.1
[INFO] [stderr]     Checking tinytemplate v1.2.1
[INFO] [stderr]     Checking half v2.7.1
[INFO] [stderr]     Checking ppv-lite86 v0.2.21
[INFO] [stderr]     Checking crossbeam-skiplist v0.1.3
[INFO] [stderr]     Checking similar v2.7.0
[INFO] [stderr]     Checking arrow-buffer v54.3.1
[INFO] [stderr]     Checking ciborium-ll v0.2.2
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking rand_chacha v0.9.0
[INFO] [stderr]     Checking proptest v1.11.0
[INFO] [stderr]     Checking ciborium v0.2.2
[INFO] [stderr]     Checking rand v0.8.6
[INFO] [stderr]     Checking arrow-data v54.3.1
[INFO] [stderr]     Checking criterion v0.5.1
[INFO] [stderr]     Checking twox-hash v1.6.3
[INFO] [stderr]     Checking arrow-array v54.3.1
[INFO] [stderr]     Checking arrow-select v54.3.1
[INFO] [stderr]     Checking arrow-arith v54.3.1
[INFO] [stderr]     Checking arrow-row v54.3.1
[INFO] [stderr]     Checking arrow-ipc v54.3.1
[INFO] [stderr]     Checking zstd v0.13.3
[INFO] [stderr]     Checking arrow-cast v54.3.1
[INFO] [stderr]     Checking arrow-string v54.3.1
[INFO] [stderr]     Checking arrow-ord v54.3.1
[INFO] [stderr]     Checking arrow v54.3.1
[INFO] [stderr]     Checking lz4 v1.28.1
[INFO] [stderr]     Checking sochdb-core v2.0.2
[INFO] [stderr]     Checking sochdb-index v2.0.2
[INFO] [stderr]     Checking sochdb-storage v2.0.2 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused imports: `Duration` and `Instant`
[INFO] [stdout]   --> src/admission_control.rs:49:17
[INFO] [stdout]    |
[INFO] [stdout] 49 | use std::time::{Duration, Instant};
[INFO] [stdout]    |                 ^^^^^^^^  ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Mutex`
[INFO] [stdout]   --> src/admission_control.rs:51:19
[INFO] [stdout]    |
[INFO] [stdout] 51 | use parking_lot::{Mutex, RwLock};
[INFO] [stdout]    |                   ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Path`
[INFO] [stdout]   --> src/durability_contract.rs:42:17
[INFO] [stdout]    |
[INFO] [stdout] 42 | use std::path::{Path, PathBuf};
[INFO] [stdout]    |                 ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]   --> src/io_isolation.rs:38:5
[INFO] [stdout]    |
[INFO] [stdout] 38 | use std::sync::Arc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `parking_lot::RwLock`
[INFO] [stdout]   --> src/io_isolation.rs:40:5
[INFO] [stdout]    |
[INFO] [stdout] 40 | use parking_lot::RwLock;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `File`
[INFO] [stdout]   --> src/mvcc_concurrent.rs:57:15
[INFO] [stdout]    |
[INFO] [stdout] 57 | use std::fs::{File, OpenOptions};
[INFO] [stdout]    |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Path`
[INFO] [stdout]   --> src/pitr.rs:46:17
[INFO] [stdout]    |
[INFO] [stdout] 46 | use std::path::{Path, PathBuf};
[INFO] [stdout]    |                 ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]   --> src/pitr.rs:48:5
[INFO] [stdout]    |
[INFO] [stdout] 48 | use std::sync::Arc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `SystemTime` and `UNIX_EPOCH`
[INFO] [stdout]   --> src/pitr.rs:49:27
[INFO] [stdout]    |
[INFO] [stdout] 49 | use std::time::{Duration, SystemTime, UNIX_EPOCH};
[INFO] [stdout]    |                           ^^^^^^^^^^  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::cmp::Ordering`
[INFO] [stdout]   --> src/ssi_scaling.rs:48:5
[INFO] [stdout]    |
[INFO] [stdout] 48 | use std::cmp::Ordering;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `BTreeMap`
[INFO] [stdout]   --> src/ssi_scaling.rs:49:24
[INFO] [stdout]    |
[INFO] [stdout] 49 | use std::collections::{BTreeMap, HashSet};
[INFO] [stdout]    |                        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `AtomicUsize`
[INFO] [stdout]   --> src/ssi_scaling.rs:50:36
[INFO] [stdout]    |
[INFO] [stdout] 50 | use std::sync::atomic::{AtomicU64, AtomicUsize, Ordering as AtomicOrdering};
[INFO] [stdout]    |                                    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]   --> src/ssi_scaling.rs:51:5
[INFO] [stdout]    |
[INFO] [stdout] 51 | use std::sync::Arc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]   --> src/queue_index.rs:71:5
[INFO] [stdout]    |
[INFO] [stdout] 71 | use std::sync::Arc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::key_buffer::ArenaKeyHandle`
[INFO] [stdout]   --> src/queue_index.rs:76:5
[INFO] [stdout]    |
[INFO] [stdout] 76 | use crate::key_buffer::ArenaKeyHandle;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Atomic`, `Owned`, `Shared`, and `self as epoch`
[INFO] [stdout]   --> src/version_set.rs:80:23
[INFO] [stdout]    |
[INFO] [stdout] 80 | use crossbeam_epoch::{self as epoch, Atomic, Owned, Shared};
[INFO] [stdout]    |                       ^^^^^^^^^^^^^  ^^^^^^  ^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::ptr`
[INFO] [stdout]   --> src/concurrent_art.rs:73:5
[INFO] [stdout]    |
[INFO] [stdout] 73 | use std::ptr;
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]   --> src/concurrent_art.rs:99:5
[INFO] [stdout]    |
[INFO] [stdout] 99 | use std::sync::Arc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Write`
[INFO] [stdout]   --> src/sstable/block.rs:64:29
[INFO] [stdout]    |
[INFO] [stdout] 64 | use std::io::{Cursor, Read, Write};
[INFO] [stdout]    |                             ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `SSTableFormat`
[INFO] [stdout]   --> src/sstable/builder.rs:32:59
[INFO] [stdout]    |
[INFO] [stdout] 32 | use super::format::{Footer, Header, Section, SectionType, SSTableFormat, HEADER_SIZE};
[INFO] [stdout]    |                                                           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]   --> src/sstable/format.rs:64:5
[INFO] [stdout]    |
[INFO] [stdout] 64 | use std::collections::HashMap;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `SeekFrom`
[INFO] [stdout]   --> src/sstable/table.rs:30:27
[INFO] [stdout]    |
[INFO] [stdout] 30 | use std::io::{Read, Seek, SeekFrom};
[INFO] [stdout]    |                           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `BlockIterator`
[INFO] [stdout]   --> src/sstable/table.rs:37:40
[INFO] [stdout]    |
[INFO] [stdout] 37 | use super::block::{Block, BlockHandle, BlockIterator, BlockType};
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `SSTableFormat` and `Section`
[INFO] [stdout]   --> src/sstable/table.rs:39:37
[INFO] [stdout]    |
[INFO] [stdout] 39 | use super::format::{Footer, Header, Section, SectionType, SSTableFormat, HEADER_SIZE};
[INFO] [stdout]    |                                     ^^^^^^^               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]   --> src/wal_segment.rs:45:5
[INFO] [stdout]    |
[INFO] [stdout] 45 | use std::sync::Arc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `BinaryHeap` and `HashMap`
[INFO] [stdout]   --> src/compaction_policy.rs:33:24
[INFO] [stdout]    |
[INFO] [stdout] 33 | use std::collections::{BinaryHeap, HashMap, HashSet};
[INFO] [stdout]    |                        ^^^^^^^^^^  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]   --> src/compaction_policy.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 | use std::sync::Arc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::BinaryHeap`
[INFO] [stdout]   --> src/optimized_scan.rs:40:5
[INFO] [stdout]    |
[INFO] [stdout] 40 | use std::collections::BinaryHeap;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]   --> src/optimized_scan.rs:41:5
[INFO] [stdout]    |
[INFO] [stdout] 41 | use std::sync::Arc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `parking_lot::RwLock`
[INFO] [stdout]   --> src/optimized_scan.rs:43:5
[INFO] [stdout]    |
[INFO] [stdout] 43 | use parking_lot::RwLock;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Duration` and `Instant`
[INFO] [stdout]   --> src/admission_control.rs:49:17
[INFO] [stdout]    |
[INFO] [stdout] 49 | use std::time::{Duration, Instant};
[INFO] [stdout]    |                 ^^^^^^^^  ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Mutex`
[INFO] [stdout]   --> src/admission_control.rs:51:19
[INFO] [stdout]    |
[INFO] [stdout] 51 | use parking_lot::{Mutex, RwLock};
[INFO] [stdout]    |                   ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Path`
[INFO] [stdout]   --> src/durability_contract.rs:42:17
[INFO] [stdout]    |
[INFO] [stdout] 42 | use std::path::{Path, PathBuf};
[INFO] [stdout]    |                 ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]   --> src/io_isolation.rs:38:5
[INFO] [stdout]    |
[INFO] [stdout] 38 | use std::sync::Arc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `parking_lot::RwLock`
[INFO] [stdout]   --> src/io_isolation.rs:40:5
[INFO] [stdout]    |
[INFO] [stdout] 40 | use parking_lot::RwLock;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `File`
[INFO] [stdout]   --> src/mvcc_concurrent.rs:57:15
[INFO] [stdout]    |
[INFO] [stdout] 57 | use std::fs::{File, OpenOptions};
[INFO] [stdout]    |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Path`
[INFO] [stdout]   --> src/pitr.rs:46:17
[INFO] [stdout]    |
[INFO] [stdout] 46 | use std::path::{Path, PathBuf};
[INFO] [stdout]    |                 ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]   --> src/pitr.rs:48:5
[INFO] [stdout]    |
[INFO] [stdout] 48 | use std::sync::Arc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `SystemTime` and `UNIX_EPOCH`
[INFO] [stdout]   --> src/pitr.rs:49:27
[INFO] [stdout]    |
[INFO] [stdout] 49 | use std::time::{Duration, SystemTime, UNIX_EPOCH};
[INFO] [stdout]    |                           ^^^^^^^^^^  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::cmp::Ordering`
[INFO] [stdout]   --> src/ssi_scaling.rs:48:5
[INFO] [stdout]    |
[INFO] [stdout] 48 | use std::cmp::Ordering;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `BTreeMap`
[INFO] [stdout]   --> src/ssi_scaling.rs:49:24
[INFO] [stdout]    |
[INFO] [stdout] 49 | use std::collections::{BTreeMap, HashSet};
[INFO] [stdout]    |                        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `AtomicUsize`
[INFO] [stdout]   --> src/ssi_scaling.rs:50:36
[INFO] [stdout]    |
[INFO] [stdout] 50 | use std::sync::atomic::{AtomicU64, AtomicUsize, Ordering as AtomicOrdering};
[INFO] [stdout]    |                                    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]   --> src/ssi_scaling.rs:51:5
[INFO] [stdout]    |
[INFO] [stdout] 51 | use std::sync::Arc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]   --> src/queue_index.rs:71:5
[INFO] [stdout]    |
[INFO] [stdout] 71 | use std::sync::Arc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::key_buffer::ArenaKeyHandle`
[INFO] [stdout]   --> src/queue_index.rs:76:5
[INFO] [stdout]    |
[INFO] [stdout] 76 | use crate::key_buffer::ArenaKeyHandle;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Atomic`, `Owned`, `Shared`, and `self as epoch`
[INFO] [stdout]   --> src/version_set.rs:80:23
[INFO] [stdout]    |
[INFO] [stdout] 80 | use crossbeam_epoch::{self as epoch, Atomic, Owned, Shared};
[INFO] [stdout]    |                       ^^^^^^^^^^^^^  ^^^^^^  ^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::ptr`
[INFO] [stdout]   --> src/concurrent_art.rs:73:5
[INFO] [stdout]    |
[INFO] [stdout] 73 | use std::ptr;
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]   --> src/concurrent_art.rs:99:5
[INFO] [stdout]    |
[INFO] [stdout] 99 | use std::sync::Arc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Write`
[INFO] [stdout]   --> src/sstable/block.rs:64:29
[INFO] [stdout]    |
[INFO] [stdout] 64 | use std::io::{Cursor, Read, Write};
[INFO] [stdout]    |                             ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `SSTableFormat`
[INFO] [stdout]   --> src/sstable/builder.rs:32:59
[INFO] [stdout]    |
[INFO] [stdout] 32 | use super::format::{Footer, Header, Section, SectionType, SSTableFormat, HEADER_SIZE};
[INFO] [stdout]    |                                                           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]   --> src/sstable/format.rs:64:5
[INFO] [stdout]    |
[INFO] [stdout] 64 | use std::collections::HashMap;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `SeekFrom`
[INFO] [stdout]   --> src/sstable/table.rs:30:27
[INFO] [stdout]    |
[INFO] [stdout] 30 | use std::io::{Read, Seek, SeekFrom};
[INFO] [stdout]    |                           ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `BlockIterator`
[INFO] [stdout]   --> src/sstable/table.rs:37:40
[INFO] [stdout]    |
[INFO] [stdout] 37 | use super::block::{Block, BlockHandle, BlockIterator, BlockType};
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `SSTableFormat` and `Section`
[INFO] [stdout]   --> src/sstable/table.rs:39:37
[INFO] [stdout]    |
[INFO] [stdout] 39 | use super::format::{Footer, Header, Section, SectionType, SSTableFormat, HEADER_SIZE};
[INFO] [stdout]    |                                     ^^^^^^^               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]   --> src/wal_segment.rs:45:5
[INFO] [stdout]    |
[INFO] [stdout] 45 | use std::sync::Arc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `BinaryHeap` and `HashMap`
[INFO] [stdout]   --> src/compaction_policy.rs:33:24
[INFO] [stdout]    |
[INFO] [stdout] 33 | use std::collections::{BinaryHeap, HashMap, HashSet};
[INFO] [stdout]    |                        ^^^^^^^^^^  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]   --> src/compaction_policy.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 | use std::sync::Arc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::BinaryHeap`
[INFO] [stdout]   --> src/optimized_scan.rs:40:5
[INFO] [stdout]    |
[INFO] [stdout] 40 | use std::collections::BinaryHeap;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]   --> src/optimized_scan.rs:41:5
[INFO] [stdout]    |
[INFO] [stdout] 41 | use std::sync::Arc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `parking_lot::RwLock`
[INFO] [stdout]   --> src/optimized_scan.rs:43:5
[INFO] [stdout]    |
[INFO] [stdout] 43 | use parking_lot::RwLock;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated struct `mvcc_snapshot::TransactionManager`: Use MvccTransactionManager from wal_integration for production workloads with durability
[INFO] [stdout]    --> src/mvcc_snapshot.rs:564:23
[INFO] [stdout]     |
[INFO] [stdout] 564 |         let manager = TransactionManager::new();
[INFO] [stdout]     |                       ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated struct `mvcc_snapshot::TransactionManager`: Use MvccTransactionManager from wal_integration for production workloads with durability
[INFO] [stdout]    --> src/mvcc_snapshot.rs:583:32
[INFO] [stdout]     |
[INFO] [stdout] 583 |         let manager = Arc::new(TransactionManager::new());
[INFO] [stdout]     |                                ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated struct `mvcc_snapshot::TransactionManager`: Use MvccTransactionManager from wal_integration for production workloads with durability
[INFO] [stdout]    --> src/mvcc_snapshot.rs:609:32
[INFO] [stdout]     |
[INFO] [stdout] 609 |         let manager = Arc::new(TransactionManager::new());
[INFO] [stdout]     |                                ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated struct `mvcc_snapshot::TransactionManager`: Use MvccTransactionManager from wal_integration for production workloads with durability
[INFO] [stdout]    --> src/mvcc_snapshot.rs:639:32
[INFO] [stdout]     |
[INFO] [stdout] 639 |         let manager = Arc::new(TransactionManager::new());
[INFO] [stdout]     |                                ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Seek`
[INFO] [stdout]   --> src/sstable/table.rs:30:21
[INFO] [stdout]    |
[INFO] [stdout] 30 | use std::io::{Read, Seek, SeekFrom};
[INFO] [stdout]    |                     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Read`
[INFO] [stdout]   --> src/sstable/table.rs:30:15
[INFO] [stdout]    |
[INFO] [stdout] 30 | use std::io::{Read, Seek, SeekFrom};
[INFO] [stdout]    |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io::Write`
[INFO] [stdout]    --> src/payload/disk_hash_index.rs:138:5
[INFO] [stdout]     |
[INFO] [stdout] 138 | use std::io::Write;
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `db`
[INFO] [stdout]   --> src/ffi.rs:67:5
[INFO] [stdout]    |
[INFO] [stdout] 67 |     db: &Database,
[INFO] [stdout]    |     ^^ help: if this is intentional, prefix it with an underscore: `_db`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `comp_type`
[INFO] [stdout]     --> src/ffi.rs:4098:9
[INFO] [stdout]      |
[INFO] [stdout] 4098 |     let comp_type = crate::compression::CompressionType::from_u8(compression);
[INFO] [stdout]      |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_comp_type`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `sql`
[INFO] [stdout]     --> src/ffi.rs:4162:9
[INFO] [stdout]      |
[INFO] [stdout] 4162 |     let sql = match unsafe { CStr::from_ptr(sql_ptr) }.to_str() {
[INFO] [stdout]      |         ^^^ help: if this is intentional, prefix it with an underscore: `_sql`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/lscs.rs:1619:13
[INFO] [stdout]      |
[INFO] [stdout] 1619 |         let mut min_row_id = u64::MAX;
[INFO] [stdout]      |             ----^^^^^^^^^^
[INFO] [stdout]      |             |
[INFO] [stdout]      |             help: remove this `mut`
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/lscs.rs:1620:13
[INFO] [stdout]      |
[INFO] [stdout] 1620 |         let mut max_row_id = 0u64;
[INFO] [stdout]      |             ----^^^^^^^^^^
[INFO] [stdout]      |             |
[INFO] [stdout]      |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Seek`
[INFO] [stdout]   --> src/sstable/table.rs:30:21
[INFO] [stdout]    |
[INFO] [stdout] 30 | use std::io::{Read, Seek, SeekFrom};
[INFO] [stdout]    |                     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Read`
[INFO] [stdout]   --> src/sstable/table.rs:30:15
[INFO] [stdout]    |
[INFO] [stdout] 30 | use std::io::{Read, Seek, SeekFrom};
[INFO] [stdout]    |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io::Write`
[INFO] [stdout]    --> src/payload/disk_hash_index.rs:138:5
[INFO] [stdout]     |
[INFO] [stdout] 138 | use std::io::Write;
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `guard`
[INFO] [stdout]    --> src/concurrent_art.rs:421:61
[INFO] [stdout]     |
[INFO] [stdout] 421 |     pub fn add_child(&self, key: u8, child: Owned<ArtNode>, guard: &Guard) -> bool {
[INFO] [stdout]     |                                                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_guard`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/sstable/block.rs:496:13
[INFO] [stdout]     |
[INFO] [stdout] 496 |         let mut iter = self.seek(key);
[INFO] [stdout]     |             ----^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `largest_key`
[INFO] [stdout]    --> src/sstable/builder.rs:278:35
[INFO] [stdout]     |
[INFO] [stdout] 278 |     fn add_index_entry(&mut self, largest_key: &[u8]) -> std::io::Result<()> {
[INFO] [stdout]     |                                   ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_largest_key`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `deficit` and `pending_count` are never read
[INFO] [stdout]    --> src/admission_control.rs:259:5
[INFO] [stdout]     |
[INFO] [stdout] 251 | pub struct TenantQuota {
[INFO] [stdout]     |            ----------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 259 |     deficit: AtomicI64,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout] 260 |     /// Queue of pending requests
[INFO] [stdout] 261 |     pending_count: AtomicU64,
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `dimension` and `metric` are never read
[INFO] [stdout]   --> src/ffi.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 37 | struct CollectionIndex {
[INFO] [stdout]    |        --------------- fields in this struct
[INFO] [stdout] 38 |     index: Arc<HnswIndex>,
[INFO] [stdout] 39 |     dimension: usize,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 40 |     metric: DistanceMetric,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `path` and `our_pid` are never read
[INFO] [stdout]    --> src/lock.rs:606:5
[INFO] [stdout]     |
[INFO] [stdout] 602 | pub struct RwDatabaseLock {
[INFO] [stdout]     |            -------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 606 |     path: PathBuf,
[INFO] [stdout]     |     ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 610 |     our_pid: u32,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `path` is never read
[INFO] [stdout]    --> src/mvcc_concurrent.rs:793:5
[INFO] [stdout]     |
[INFO] [stdout] 791 | pub struct ConcurrentMvcc {
[INFO] [stdout]     |            -------------- field in this struct
[INFO] [stdout] 792 |     /// Path to database
[INFO] [stdout] 793 |     path: PathBuf,
[INFO] [stdout]     |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `path` is never read
[INFO] [stdout]    --> src/wal_fencing.rs:376:5
[INFO] [stdout]     |
[INFO] [stdout] 374 | pub struct FencedWal {
[INFO] [stdout]     |            --------- field in this struct
[INFO] [stdout] 375 |     /// Path to WAL file
[INFO] [stdout] 376 |     path: PathBuf,
[INFO] [stdout]     |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `filter_batch_scalar` is never used
[INFO] [stdout]    --> src/vectorized_scan.rs:649:8
[INFO] [stdout]     |
[INFO] [stdout] 613 | impl SimdVisibilityFilter {
[INFO] [stdout]     | ------------------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 649 |     fn filter_batch_scalar(commit_ts: &[u64], snapshot_ts: u64, out: &mut [bool]) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `config` is never read
[INFO] [stdout]    --> src/io_uring.rs:441:5
[INFO] [stdout]     |
[INFO] [stdout] 439 | pub struct LinuxIoUringBackend {
[INFO] [stdout]     |            ------------------- field in this struct
[INFO] [stdout] 440 |     uring: Option<IoUring>,
[INFO] [stdout] 441 |     config: IoUringConfig,
[INFO] [stdout]     |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `check_uring_available` is never used
[INFO] [stdout]    --> src/io_uring.rs:476:8
[INFO] [stdout]     |
[INFO] [stdout] 450 | impl LinuxIoUringBackend {
[INFO] [stdout]     | ------------------------ associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 476 |     fn check_uring_available() -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RestartPoint` is never constructed
[INFO] [stdout]    --> src/sstable/block.rs:150:8
[INFO] [stdout]     |
[INFO] [stdout] 150 | struct RestartPoint {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `HashBucket` is never constructed
[INFO] [stdout]    --> src/sstable/block.rs:157:8
[INFO] [stdout]     |
[INFO] [stdout] 157 | struct HashBucket {
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `num_hash_buckets` is never read
[INFO] [stdout]    --> src/sstable/block.rs:357:5
[INFO] [stdout]     |
[INFO] [stdout] 349 | pub struct Block {
[INFO] [stdout]     |            ----- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 357 |     num_hash_buckets: usize,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `num_slots` is never read
[INFO] [stdout]    --> src/sstable/filter.rs:418:5
[INFO] [stdout]     |
[INFO] [stdout] 412 | struct RibbonFilterBuilder {
[INFO] [stdout]     |        ------------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 418 |     num_slots: usize,
[INFO] [stdout]     |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `header`, `footer`, and `index` are never read
[INFO] [stdout]    --> src/sstable/table.rs:118:5
[INFO] [stdout]     |
[INFO] [stdout] 110 | pub struct SSTable {
[INFO] [stdout]     |            ------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 118 |     header: Header,
[INFO] [stdout]     |     ^^^^^^
[INFO] [stdout] 119 |     /// Parsed footer with sections
[INFO] [stdout] 120 |     footer: Footer,
[INFO] [stdout]     |     ^^^^^^
[INFO] [stdout] 121 |     /// Index block (cached)
[INFO] [stdout] 122 |     index: Vec<u8>,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `path` is never read
[INFO] [stdout]    --> src/wal_segment.rs:188:5
[INFO] [stdout]     |
[INFO] [stdout] 184 | struct ActiveSegment {
[INFO] [stdout]     |        ------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 188 |     path: PathBuf,
[INFO] [stdout]     |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `config` is never read
[INFO] [stdout]    --> src/compaction_policy.rs:470:5
[INFO] [stdout]     |
[INFO] [stdout] 469 | pub struct UniversalCompactionPicker {
[INFO] [stdout]     |            ------------------------- field in this struct
[INFO] [stdout] 470 |     config: CompactionConfig,
[INFO] [stdout]     |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/sstable/table.rs:410:17
[INFO] [stdout]     |
[INFO] [stdout] 410 |     pub fn iter(&self) -> SSTableIterator {
[INFO] [stdout]     |                 ^^^^^     ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 410 |     pub fn iter(&self) -> SSTableIterator<'_> {
[INFO] [stdout]     |                                          ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/sstable/table.rs:416:9
[INFO] [stdout]     |
[INFO] [stdout] 416 |         &self,
[INFO] [stdout]     |         ^^^^^ the lifetime is elided here
[INFO] [stdout] ...
[INFO] [stdout] 419 |     ) -> RangeIterator {
[INFO] [stdout]     |          ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 419 |     ) -> RangeIterator<'_> {
[INFO] [stdout]     |                       ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/wal_segment.rs:574:30
[INFO] [stdout]     |
[INFO] [stdout] 574 |     pub fn recovery_iterator(&self, from_lsn: u64) -> RecoveryIterator {
[INFO] [stdout]     |                              ^^^^^                    ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                              |
[INFO] [stdout]     |                              the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 574 |     pub fn recovery_iterator(&self, from_lsn: u64) -> RecoveryIterator<'_> {
[INFO] [stdout]     |                                                                       ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/encryption.rs:325:13
[INFO] [stdout]     |
[INFO] [stdout] 325 |         let mut fake = vec![99u8; 50];
[INFO] [stdout]     |             ----^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/encryption.rs:331:13
[INFO] [stdout]     |
[INFO] [stdout] 331 |         let mut key = EncryptionKey::new(generate_key());
[INFO] [stdout]     |             ----^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `db`
[INFO] [stdout]   --> src/ffi.rs:67:5
[INFO] [stdout]    |
[INFO] [stdout] 67 |     db: &Database,
[INFO] [stdout]    |     ^^ help: if this is intentional, prefix it with an underscore: `_db`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `comp_type`
[INFO] [stdout]     --> src/ffi.rs:4098:9
[INFO] [stdout]      |
[INFO] [stdout] 4098 |     let comp_type = crate::compression::CompressionType::from_u8(compression);
[INFO] [stdout]      |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_comp_type`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `sql`
[INFO] [stdout]     --> src/ffi.rs:4162:9
[INFO] [stdout]      |
[INFO] [stdout] 4162 |     let sql = match unsafe { CStr::from_ptr(sql_ptr) }.to_str() {
[INFO] [stdout]      |         ^^^ help: if this is intentional, prefix it with an underscore: `_sql`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]   --> benches/measurement_harness.rs:43:5
[INFO] [stdout]    |
[INFO] [stdout] 43 | use std::collections::HashMap;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::*`
[INFO] [stdout]    --> benches/measurement_harness.rs:717:9
[INFO] [stdout]     |
[INFO] [stdout] 717 |     use super::*;
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `generate_value`
[INFO] [stdout]   --> benches/bench_point_read.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     generate_value, next_key_index,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]   --> benches/measurement_harness.rs:43:5
[INFO] [stdout]    |
[INFO] [stdout] 43 | use std::collections::HashMap;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::*`
[INFO] [stdout]    --> benches/measurement_harness.rs:717:9
[INFO] [stdout]     |
[INFO] [stdout] 717 |     use super::*;
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]   --> benches/measurement_harness.rs:43:5
[INFO] [stdout]    |
[INFO] [stdout] 43 | use std::collections::HashMap;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]   --> benches/measurement_harness.rs:43:5
[INFO] [stdout]    |
[INFO] [stdout] 43 | use std::collections::HashMap;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::*`
[INFO] [stdout]    --> benches/measurement_harness.rs:717:9
[INFO] [stdout]     |
[INFO] [stdout] 717 |     use super::*;
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::*`
[INFO] [stdout]    --> benches/measurement_harness.rs:717:9
[INFO] [stdout]     |
[INFO] [stdout] 717 |     use super::*;
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]   --> benches/measurement_harness.rs:43:5
[INFO] [stdout]    |
[INFO] [stdout] 43 | use std::collections::HashMap;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::*`
[INFO] [stdout]    --> benches/measurement_harness.rs:717:9
[INFO] [stdout]     |
[INFO] [stdout] 717 |     use super::*;
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]   --> benches/measurement_harness.rs:43:5
[INFO] [stdout]    |
[INFO] [stdout] 43 | use std::collections::HashMap;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::*`
[INFO] [stdout]    --> benches/measurement_harness.rs:717:9
[INFO] [stdout]     |
[INFO] [stdout] 717 |     use super::*;
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SMALL_DATASET` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:53:11
[INFO] [stdout]    |
[INFO] [stdout] 53 | pub const SMALL_DATASET: usize = 10_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE_DATASET` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:55:11
[INFO] [stdout]    |
[INFO] [stdout] 55 | pub const LARGE_DATASET: usize = 10_000_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEDIUM_VALUE_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:60:11
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub const MEDIUM_VALUE_SIZE: usize = 1_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE_VALUE_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:61:11
[INFO] [stdout]    |
[INFO] [stdout] 61 | pub const LARGE_VALUE_SIZE: usize = 10_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:145:12
[INFO] [stdout]     |
[INFO] [stdout] 143 | impl BenchConfig {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout] 144 |     /// Create config for small dataset
[INFO] [stdout] 145 |     pub fn small() -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 153 |     pub fn large() -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 161 |     pub fn with_uniform(mut self) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 167 |     pub fn with_sequential(mut self) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 173 |     pub fn with_value_size(mut self, size: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 179 |     pub fn with_sync_mode(mut self, mode: SyncMode) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 185 |     pub fn with_threads(mut self, n: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 191 |     pub fn with_dataset_size(mut self, size: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 197 |     pub fn with_measurement_ops(mut self, ops: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `zeta_2` is never read
[INFO] [stdout]    --> benches/measurement_harness.rs:215:5
[INFO] [stdout]     |
[INFO] [stdout] 211 | pub struct ZipfianGenerator {
[INFO] [stdout]     |            ---------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 215 |     zeta_2: f64,
[INFO] [stdout]     |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BenchStats` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:312:12
[INFO] [stdout]     |
[INFO] [stdout] 312 | pub struct BenchStats {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BenchResults` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:327:12
[INFO] [stdout]     |
[INFO] [stdout] 327 | pub struct BenchResults {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LatencyStats` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:340:12
[INFO] [stdout]     |
[INFO] [stdout] 340 | pub struct LatencyStats {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_sorted` is never used
[INFO] [stdout]    --> benches/measurement_harness.rs:352:12
[INFO] [stdout]     |
[INFO] [stdout] 350 | impl LatencyStats {
[INFO] [stdout]     | ----------------- associated function in this implementation
[INFO] [stdout] 351 |     /// Calculate latency stats from a sorted slice of microsecond values
[INFO] [stdout] 352 |     pub fn from_sorted(samples: &[f64]) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `HardwareInfo` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:382:12
[INFO] [stdout]     |
[INFO] [stdout] 382 | pub struct HardwareInfo {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `print_summary`, and `to_json` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:402:12
[INFO] [stdout]     |
[INFO] [stdout] 400 | impl BenchStats {
[INFO] [stdout]     | --------------- associated items in this implementation
[INFO] [stdout] 401 |     /// Create new benchmark stats
[INFO] [stdout] 402 |     pub fn new(
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 436 |     pub fn print_summary(&self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 457 |     pub fn to_json(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `set_sync_mode`, `run_point_reads`, `run_writes`, and `run_scans` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:503:12
[INFO] [stdout]     |
[INFO] [stdout] 472 | impl DurableStorageHarness {
[INFO] [stdout]     | -------------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 503 |     pub fn set_sync_mode(&self, mode: SyncMode) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 534 |     pub fn run_point_reads(&self, config: &BenchConfig) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 584 |     pub fn run_writes(&self, config: &BenchConfig) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 617 |     pub fn run_scans(&self, config: &BenchConfig, scan_size: usize) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `YcsbWorkload` is never used
[INFO] [stdout]    --> benches/measurement_harness.rs:653:10
[INFO] [stdout]     |
[INFO] [stdout] 653 | pub enum YcsbWorkload {
[INFO] [stdout]     |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `read_ratio`, `update_ratio`, `scan_ratio`, and `insert_ratio` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:670:12
[INFO] [stdout]     |
[INFO] [stdout] 668 | impl YcsbWorkload {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] 669 |     /// Get the read ratio for this workload
[INFO] [stdout] 670 |     pub fn read_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 682 |     pub fn update_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 694 |     pub fn scan_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 702 |     pub fn insert_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]   --> benches/measurement_harness.rs:43:5
[INFO] [stdout]    |
[INFO] [stdout] 43 | use std::collections::HashMap;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::*`
[INFO] [stdout]    --> benches/measurement_harness.rs:717:9
[INFO] [stdout]     |
[INFO] [stdout] 717 |     use super::*;
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]   --> benches/measurement_harness.rs:43:5
[INFO] [stdout]    |
[INFO] [stdout] 43 | use std::collections::HashMap;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::*`
[INFO] [stdout]    --> benches/measurement_harness.rs:717:9
[INFO] [stdout]     |
[INFO] [stdout] 717 |     use super::*;
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SMALL_DATASET` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:53:11
[INFO] [stdout]    |
[INFO] [stdout] 53 | pub const SMALL_DATASET: usize = 10_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE_DATASET` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:55:11
[INFO] [stdout]    |
[INFO] [stdout] 55 | pub const LARGE_DATASET: usize = 10_000_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEDIUM_VALUE_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:60:11
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub const MEDIUM_VALUE_SIZE: usize = 1_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE_VALUE_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:61:11
[INFO] [stdout]    |
[INFO] [stdout] 61 | pub const LARGE_VALUE_SIZE: usize = 10_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:145:12
[INFO] [stdout]     |
[INFO] [stdout] 143 | impl BenchConfig {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout] 144 |     /// Create config for small dataset
[INFO] [stdout] 145 |     pub fn small() -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 153 |     pub fn large() -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 161 |     pub fn with_uniform(mut self) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 167 |     pub fn with_sequential(mut self) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 173 |     pub fn with_value_size(mut self, size: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 179 |     pub fn with_sync_mode(mut self, mode: SyncMode) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 185 |     pub fn with_threads(mut self, n: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 191 |     pub fn with_dataset_size(mut self, size: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 197 |     pub fn with_measurement_ops(mut self, ops: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ZipfianGenerator` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:211:12
[INFO] [stdout]     |
[INFO] [stdout] 211 | pub struct ZipfianGenerator {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `zeta`, and `next` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:222:12
[INFO] [stdout]     |
[INFO] [stdout] 220 | impl ZipfianGenerator {
[INFO] [stdout]     | --------------------- associated items in this implementation
[INFO] [stdout] 221 |     /// Create a new Zipfian generator for n items with skew theta
[INFO] [stdout] 222 |     pub fn new(n: usize, theta: f64) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 240 |     fn zeta(n: usize, theta: f64) -> f64 {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 245 |     pub fn next<R: Rng>(&self, rng: &mut R) -> usize {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `next_key_index` is never used
[INFO] [stdout]    --> benches/measurement_harness.rs:288:8
[INFO] [stdout]     |
[INFO] [stdout] 288 | pub fn next_key_index<R: Rng>(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BenchStats` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:312:12
[INFO] [stdout]     |
[INFO] [stdout] 312 | pub struct BenchStats {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BenchResults` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:327:12
[INFO] [stdout]     |
[INFO] [stdout] 327 | pub struct BenchResults {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LatencyStats` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:340:12
[INFO] [stdout]     |
[INFO] [stdout] 340 | pub struct LatencyStats {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_sorted` is never used
[INFO] [stdout]    --> benches/measurement_harness.rs:352:12
[INFO] [stdout]     |
[INFO] [stdout] 350 | impl LatencyStats {
[INFO] [stdout]     | ----------------- associated function in this implementation
[INFO] [stdout] 351 |     /// Calculate latency stats from a sorted slice of microsecond values
[INFO] [stdout] 352 |     pub fn from_sorted(samples: &[f64]) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `HardwareInfo` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:382:12
[INFO] [stdout]     |
[INFO] [stdout] 382 | pub struct HardwareInfo {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `print_summary`, and `to_json` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:402:12
[INFO] [stdout]     |
[INFO] [stdout] 400 | impl BenchStats {
[INFO] [stdout]     | --------------- associated items in this implementation
[INFO] [stdout] 401 |     /// Create new benchmark stats
[INFO] [stdout] 402 |     pub fn new(
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 436 |     pub fn print_summary(&self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 457 |     pub fn to_json(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `set_sync_mode`, `run_point_reads`, `run_writes`, and `run_scans` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:474:12
[INFO] [stdout]     |
[INFO] [stdout] 472 | impl DurableStorageHarness {
[INFO] [stdout]     | -------------------------- associated items in this implementation
[INFO] [stdout] 473 |     /// Create a new harness with default configuration
[INFO] [stdout] 474 |     pub fn new() -> anyhow::Result<Self> {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 503 |     pub fn set_sync_mode(&self, mode: SyncMode) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 534 |     pub fn run_point_reads(&self, config: &BenchConfig) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 584 |     pub fn run_writes(&self, config: &BenchConfig) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 617 |     pub fn run_scans(&self, config: &BenchConfig, scan_size: usize) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `YcsbWorkload` is never used
[INFO] [stdout]    --> benches/measurement_harness.rs:653:10
[INFO] [stdout]     |
[INFO] [stdout] 653 | pub enum YcsbWorkload {
[INFO] [stdout]     |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `read_ratio`, `update_ratio`, `scan_ratio`, and `insert_ratio` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:670:12
[INFO] [stdout]     |
[INFO] [stdout] 668 | impl YcsbWorkload {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] 669 |     /// Get the read ratio for this workload
[INFO] [stdout] 670 |     pub fn read_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 682 |     pub fn update_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 694 |     pub fn scan_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 702 |     pub fn insert_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SMALL_DATASET` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:53:11
[INFO] [stdout]    |
[INFO] [stdout] 53 | pub const SMALL_DATASET: usize = 10_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEDIUM_DATASET` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:54:11
[INFO] [stdout]    |
[INFO] [stdout] 54 | pub const MEDIUM_DATASET: usize = 1_000_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE_DATASET` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:55:11
[INFO] [stdout]    |
[INFO] [stdout] 55 | pub const LARGE_DATASET: usize = 10_000_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_KEY_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:58:11
[INFO] [stdout]    |
[INFO] [stdout] 58 | pub const DEFAULT_KEY_SIZE: usize = 16;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SMALL_VALUE_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:59:11
[INFO] [stdout]    |
[INFO] [stdout] 59 | pub const SMALL_VALUE_SIZE: usize = 100;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEDIUM_VALUE_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:60:11
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub const MEDIUM_VALUE_SIZE: usize = 1_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE_VALUE_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:61:11
[INFO] [stdout]    |
[INFO] [stdout] 61 | pub const LARGE_VALUE_SIZE: usize = 10_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ZIPF_THETA` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:64:11
[INFO] [stdout]    |
[INFO] [stdout] 64 | pub const ZIPF_THETA: f64 = 0.99;
[INFO] [stdout]    |           ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_WARMUP_OPS` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:67:11
[INFO] [stdout]    |
[INFO] [stdout] 67 | pub const DEFAULT_WARMUP_OPS: usize = 1_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_MEASUREMENT_OPS` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:68:11
[INFO] [stdout]    |
[INFO] [stdout] 68 | pub const DEFAULT_MEASUREMENT_OPS: usize = 10_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Distribution` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:72:10
[INFO] [stdout]    |
[INFO] [stdout] 72 | pub enum Distribution {
[INFO] [stdout]    |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `SyncMode` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:89:10
[INFO] [stdout]    |
[INFO] [stdout] 89 | pub enum SyncMode {
[INFO] [stdout]    |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BenchConfig` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:106:12
[INFO] [stdout]     |
[INFO] [stdout] 106 | pub struct BenchConfig {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:145:12
[INFO] [stdout]     |
[INFO] [stdout] 143 | impl BenchConfig {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout] 144 |     /// Create config for small dataset
[INFO] [stdout] 145 |     pub fn small() -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 153 |     pub fn large() -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 161 |     pub fn with_uniform(mut self) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 167 |     pub fn with_sequential(mut self) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 173 |     pub fn with_value_size(mut self, size: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 179 |     pub fn with_sync_mode(mut self, mode: SyncMode) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 185 |     pub fn with_threads(mut self, n: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 191 |     pub fn with_dataset_size(mut self, size: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 197 |     pub fn with_measurement_ops(mut self, ops: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ZipfianGenerator` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:211:12
[INFO] [stdout]     |
[INFO] [stdout] 211 | pub struct ZipfianGenerator {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `zeta`, and `next` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:222:12
[INFO] [stdout]     |
[INFO] [stdout] 220 | impl ZipfianGenerator {
[INFO] [stdout]     | --------------------- associated items in this implementation
[INFO] [stdout] 221 |     /// Create a new Zipfian generator for n items with skew theta
[INFO] [stdout] 222 |     pub fn new(n: usize, theta: f64) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 240 |     fn zeta(n: usize, theta: f64) -> f64 {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 245 |     pub fn next<R: Rng>(&self, rng: &mut R) -> usize {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `next_key_index` is never used
[INFO] [stdout]    --> benches/measurement_harness.rs:288:8
[INFO] [stdout]     |
[INFO] [stdout] 288 | pub fn next_key_index<R: Rng>(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BenchStats` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:312:12
[INFO] [stdout]     |
[INFO] [stdout] 312 | pub struct BenchStats {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BenchResults` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:327:12
[INFO] [stdout]     |
[INFO] [stdout] 327 | pub struct BenchResults {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LatencyStats` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:340:12
[INFO] [stdout]     |
[INFO] [stdout] 340 | pub struct LatencyStats {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_sorted` is never used
[INFO] [stdout]    --> benches/measurement_harness.rs:352:12
[INFO] [stdout]     |
[INFO] [stdout] 350 | impl LatencyStats {
[INFO] [stdout]     | ----------------- associated function in this implementation
[INFO] [stdout] 351 |     /// Calculate latency stats from a sorted slice of microsecond values
[INFO] [stdout] 352 |     pub fn from_sorted(samples: &[f64]) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `HardwareInfo` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:382:12
[INFO] [stdout]     |
[INFO] [stdout] 382 | pub struct HardwareInfo {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `print_summary`, and `to_json` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:402:12
[INFO] [stdout]     |
[INFO] [stdout] 400 | impl BenchStats {
[INFO] [stdout]     | --------------- associated items in this implementation
[INFO] [stdout] 401 |     /// Create new benchmark stats
[INFO] [stdout] 402 |     pub fn new(
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 436 |     pub fn print_summary(&self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 457 |     pub fn to_json(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DurableStorageHarness` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:467:12
[INFO] [stdout]     |
[INFO] [stdout] 467 | pub struct DurableStorageHarness {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:474:12
[INFO] [stdout]     |
[INFO] [stdout] 472 | impl DurableStorageHarness {
[INFO] [stdout]     | -------------------------- associated items in this implementation
[INFO] [stdout] 473 |     /// Create a new harness with default configuration
[INFO] [stdout] 474 |     pub fn new() -> anyhow::Result<Self> {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 483 |     pub fn with_config(enable_ordered_index: bool, enable_group_commit: bool) -> anyhow::Result<Self> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 498 |     pub fn storage(&self) -> &DurableStorage {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 503 |     pub fn set_sync_mode(&self, mode: SyncMode) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 508 |     pub fn preload(&self, config: &BenchConfig) -> anyhow::Result<Duration> {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 534 |     pub fn run_point_reads(&self, config: &BenchConfig) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 584 |     pub fn run_writes(&self, config: &BenchConfig) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 617 |     pub fn run_scans(&self, config: &BenchConfig, scan_size: usize) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `YcsbWorkload` is never used
[INFO] [stdout]    --> benches/measurement_harness.rs:653:10
[INFO] [stdout]     |
[INFO] [stdout] 653 | pub enum YcsbWorkload {
[INFO] [stdout]     |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `read_ratio`, `update_ratio`, `scan_ratio`, and `insert_ratio` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:670:12
[INFO] [stdout]     |
[INFO] [stdout] 668 | impl YcsbWorkload {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] 669 |     /// Get the read ratio for this workload
[INFO] [stdout] 670 |     pub fn read_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 682 |     pub fn update_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 694 |     pub fn scan_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 702 |     pub fn insert_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/lscs.rs:1619:13
[INFO] [stdout]      |
[INFO] [stdout] 1619 |         let mut min_row_id = u64::MAX;
[INFO] [stdout]      |             ----^^^^^^^^^^
[INFO] [stdout]      |             |
[INFO] [stdout]      |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/lscs.rs:1620:13
[INFO] [stdout]      |
[INFO] [stdout] 1620 |         let mut max_row_id = 0u64;
[INFO] [stdout]      |             ----^^^^^^^^^^
[INFO] [stdout]      |             |
[INFO] [stdout]      |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SMALL_DATASET` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:53:11
[INFO] [stdout]    |
[INFO] [stdout] 53 | pub const SMALL_DATASET: usize = 10_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE_DATASET` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:55:11
[INFO] [stdout]    |
[INFO] [stdout] 55 | pub const LARGE_DATASET: usize = 10_000_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEDIUM_VALUE_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:60:11
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub const MEDIUM_VALUE_SIZE: usize = 1_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE_VALUE_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:61:11
[INFO] [stdout]    |
[INFO] [stdout] 61 | pub const LARGE_VALUE_SIZE: usize = 10_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:145:12
[INFO] [stdout]     |
[INFO] [stdout] 143 | impl BenchConfig {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout] 144 |     /// Create config for small dataset
[INFO] [stdout] 145 |     pub fn small() -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 153 |     pub fn large() -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 161 |     pub fn with_uniform(mut self) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 167 |     pub fn with_sequential(mut self) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 173 |     pub fn with_value_size(mut self, size: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 179 |     pub fn with_sync_mode(mut self, mode: SyncMode) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 185 |     pub fn with_threads(mut self, n: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 191 |     pub fn with_dataset_size(mut self, size: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 197 |     pub fn with_measurement_ops(mut self, ops: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `zeta_2` is never read
[INFO] [stdout]    --> benches/measurement_harness.rs:215:5
[INFO] [stdout]     |
[INFO] [stdout] 211 | pub struct ZipfianGenerator {
[INFO] [stdout]     |            ---------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 215 |     zeta_2: f64,
[INFO] [stdout]     |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BenchStats` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:312:12
[INFO] [stdout]     |
[INFO] [stdout] 312 | pub struct BenchStats {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BenchResults` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:327:12
[INFO] [stdout]     |
[INFO] [stdout] 327 | pub struct BenchResults {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LatencyStats` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:340:12
[INFO] [stdout]     |
[INFO] [stdout] 340 | pub struct LatencyStats {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_sorted` is never used
[INFO] [stdout]    --> benches/measurement_harness.rs:352:12
[INFO] [stdout]     |
[INFO] [stdout] 350 | impl LatencyStats {
[INFO] [stdout]     | ----------------- associated function in this implementation
[INFO] [stdout] 351 |     /// Calculate latency stats from a sorted slice of microsecond values
[INFO] [stdout] 352 |     pub fn from_sorted(samples: &[f64]) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `HardwareInfo` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:382:12
[INFO] [stdout]     |
[INFO] [stdout] 382 | pub struct HardwareInfo {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `print_summary`, and `to_json` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:402:12
[INFO] [stdout]     |
[INFO] [stdout] 400 | impl BenchStats {
[INFO] [stdout]     | --------------- associated items in this implementation
[INFO] [stdout] 401 |     /// Create new benchmark stats
[INFO] [stdout] 402 |     pub fn new(
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 436 |     pub fn print_summary(&self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 457 |     pub fn to_json(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `set_sync_mode`, `run_point_reads`, `run_writes`, and `run_scans` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:503:12
[INFO] [stdout]     |
[INFO] [stdout] 472 | impl DurableStorageHarness {
[INFO] [stdout]     | -------------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 503 |     pub fn set_sync_mode(&self, mode: SyncMode) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 534 |     pub fn run_point_reads(&self, config: &BenchConfig) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 584 |     pub fn run_writes(&self, config: &BenchConfig) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 617 |     pub fn run_scans(&self, config: &BenchConfig, scan_size: usize) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `insert_ratio` is never used
[INFO] [stdout]    --> benches/measurement_harness.rs:702:12
[INFO] [stdout]     |
[INFO] [stdout] 668 | impl YcsbWorkload {
[INFO] [stdout]     | ----------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 702 |     pub fn insert_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SMALL_DATASET` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:53:11
[INFO] [stdout]    |
[INFO] [stdout] 53 | pub const SMALL_DATASET: usize = 10_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEDIUM_DATASET` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:54:11
[INFO] [stdout]    |
[INFO] [stdout] 54 | pub const MEDIUM_DATASET: usize = 1_000_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE_DATASET` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:55:11
[INFO] [stdout]    |
[INFO] [stdout] 55 | pub const LARGE_DATASET: usize = 10_000_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_KEY_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:58:11
[INFO] [stdout]    |
[INFO] [stdout] 58 | pub const DEFAULT_KEY_SIZE: usize = 16;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SMALL_VALUE_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:59:11
[INFO] [stdout]    |
[INFO] [stdout] 59 | pub const SMALL_VALUE_SIZE: usize = 100;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEDIUM_VALUE_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:60:11
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub const MEDIUM_VALUE_SIZE: usize = 1_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE_VALUE_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:61:11
[INFO] [stdout]    |
[INFO] [stdout] 61 | pub const LARGE_VALUE_SIZE: usize = 10_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ZIPF_THETA` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:64:11
[INFO] [stdout]    |
[INFO] [stdout] 64 | pub const ZIPF_THETA: f64 = 0.99;
[INFO] [stdout]    |           ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_WARMUP_OPS` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:67:11
[INFO] [stdout]    |
[INFO] [stdout] 67 | pub const DEFAULT_WARMUP_OPS: usize = 1_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_MEASUREMENT_OPS` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:68:11
[INFO] [stdout]    |
[INFO] [stdout] 68 | pub const DEFAULT_MEASUREMENT_OPS: usize = 10_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Distribution` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:72:10
[INFO] [stdout]    |
[INFO] [stdout] 72 | pub enum Distribution {
[INFO] [stdout]    |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `SyncMode` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:89:10
[INFO] [stdout]    |
[INFO] [stdout] 89 | pub enum SyncMode {
[INFO] [stdout]    |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BenchConfig` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:106:12
[INFO] [stdout]     |
[INFO] [stdout] 106 | pub struct BenchConfig {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:145:12
[INFO] [stdout]     |
[INFO] [stdout] 143 | impl BenchConfig {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout] 144 |     /// Create config for small dataset
[INFO] [stdout] 145 |     pub fn small() -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 153 |     pub fn large() -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 161 |     pub fn with_uniform(mut self) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 167 |     pub fn with_sequential(mut self) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 173 |     pub fn with_value_size(mut self, size: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 179 |     pub fn with_sync_mode(mut self, mode: SyncMode) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 185 |     pub fn with_threads(mut self, n: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 191 |     pub fn with_dataset_size(mut self, size: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 197 |     pub fn with_measurement_ops(mut self, ops: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ZipfianGenerator` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:211:12
[INFO] [stdout]     |
[INFO] [stdout] 211 | pub struct ZipfianGenerator {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `zeta`, and `next` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:222:12
[INFO] [stdout]     |
[INFO] [stdout] 220 | impl ZipfianGenerator {
[INFO] [stdout]     | --------------------- associated items in this implementation
[INFO] [stdout] 221 |     /// Create a new Zipfian generator for n items with skew theta
[INFO] [stdout] 222 |     pub fn new(n: usize, theta: f64) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 240 |     fn zeta(n: usize, theta: f64) -> f64 {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 245 |     pub fn next<R: Rng>(&self, rng: &mut R) -> usize {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `next_key_index` is never used
[INFO] [stdout]    --> benches/measurement_harness.rs:288:8
[INFO] [stdout]     |
[INFO] [stdout] 288 | pub fn next_key_index<R: Rng>(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BenchStats` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:312:12
[INFO] [stdout]     |
[INFO] [stdout] 312 | pub struct BenchStats {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BenchResults` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:327:12
[INFO] [stdout]     |
[INFO] [stdout] 327 | pub struct BenchResults {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LatencyStats` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:340:12
[INFO] [stdout]     |
[INFO] [stdout] 340 | pub struct LatencyStats {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_sorted` is never used
[INFO] [stdout]    --> benches/measurement_harness.rs:352:12
[INFO] [stdout]     |
[INFO] [stdout] 350 | impl LatencyStats {
[INFO] [stdout]     | ----------------- associated function in this implementation
[INFO] [stdout] 351 |     /// Calculate latency stats from a sorted slice of microsecond values
[INFO] [stdout] 352 |     pub fn from_sorted(samples: &[f64]) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `HardwareInfo` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:382:12
[INFO] [stdout]     |
[INFO] [stdout] 382 | pub struct HardwareInfo {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `print_summary`, and `to_json` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:402:12
[INFO] [stdout]     |
[INFO] [stdout] 400 | impl BenchStats {
[INFO] [stdout]     | --------------- associated items in this implementation
[INFO] [stdout] 401 |     /// Create new benchmark stats
[INFO] [stdout] 402 |     pub fn new(
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 436 |     pub fn print_summary(&self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 457 |     pub fn to_json(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DurableStorageHarness` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:467:12
[INFO] [stdout]     |
[INFO] [stdout] 467 | pub struct DurableStorageHarness {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:474:12
[INFO] [stdout]     |
[INFO] [stdout] 472 | impl DurableStorageHarness {
[INFO] [stdout]     | -------------------------- associated items in this implementation
[INFO] [stdout] 473 |     /// Create a new harness with default configuration
[INFO] [stdout] 474 |     pub fn new() -> anyhow::Result<Self> {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 483 |     pub fn with_config(enable_ordered_index: bool, enable_group_commit: bool) -> anyhow::Result<Self> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 498 |     pub fn storage(&self) -> &DurableStorage {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 503 |     pub fn set_sync_mode(&self, mode: SyncMode) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 508 |     pub fn preload(&self, config: &BenchConfig) -> anyhow::Result<Duration> {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 534 |     pub fn run_point_reads(&self, config: &BenchConfig) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 584 |     pub fn run_writes(&self, config: &BenchConfig) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 617 |     pub fn run_scans(&self, config: &BenchConfig, scan_size: usize) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `YcsbWorkload` is never used
[INFO] [stdout]    --> benches/measurement_harness.rs:653:10
[INFO] [stdout]     |
[INFO] [stdout] 653 | pub enum YcsbWorkload {
[INFO] [stdout]     |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `read_ratio`, `update_ratio`, `scan_ratio`, and `insert_ratio` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:670:12
[INFO] [stdout]     |
[INFO] [stdout] 668 | impl YcsbWorkload {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] 669 |     /// Get the read ratio for this workload
[INFO] [stdout] 670 |     pub fn read_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 682 |     pub fn update_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 694 |     pub fn scan_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 702 |     pub fn insert_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]   --> benches/measurement_harness.rs:43:5
[INFO] [stdout]    |
[INFO] [stdout] 43 | use std::collections::HashMap;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::*`
[INFO] [stdout]    --> benches/measurement_harness.rs:717:9
[INFO] [stdout]     |
[INFO] [stdout] 717 |     use super::*;
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `BenchConfig` and `DurableStorageHarness`
[INFO] [stdout]   --> benches/bench_concurrency.rs:38:5
[INFO] [stdout]    |
[INFO] [stdout] 38 |     BenchConfig, Distribution, DurableStorageHarness, ZipfianGenerator,
[INFO] [stdout]    |     ^^^^^^^^^^^                ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SMALL_DATASET` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:53:11
[INFO] [stdout]    |
[INFO] [stdout] 53 | pub const SMALL_DATASET: usize = 10_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE_DATASET` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:55:11
[INFO] [stdout]    |
[INFO] [stdout] 55 | pub const LARGE_DATASET: usize = 10_000_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEDIUM_VALUE_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:60:11
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub const MEDIUM_VALUE_SIZE: usize = 1_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE_VALUE_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:61:11
[INFO] [stdout]    |
[INFO] [stdout] 61 | pub const LARGE_VALUE_SIZE: usize = 10_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:145:12
[INFO] [stdout]     |
[INFO] [stdout] 143 | impl BenchConfig {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout] 144 |     /// Create config for small dataset
[INFO] [stdout] 145 |     pub fn small() -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 153 |     pub fn large() -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 161 |     pub fn with_uniform(mut self) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 167 |     pub fn with_sequential(mut self) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 173 |     pub fn with_value_size(mut self, size: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 179 |     pub fn with_sync_mode(mut self, mode: SyncMode) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 185 |     pub fn with_threads(mut self, n: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 191 |     pub fn with_dataset_size(mut self, size: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 197 |     pub fn with_measurement_ops(mut self, ops: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ZipfianGenerator` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:211:12
[INFO] [stdout]     |
[INFO] [stdout] 211 | pub struct ZipfianGenerator {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `zeta`, and `next` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:222:12
[INFO] [stdout]     |
[INFO] [stdout] 220 | impl ZipfianGenerator {
[INFO] [stdout]     | --------------------- associated items in this implementation
[INFO] [stdout] 221 |     /// Create a new Zipfian generator for n items with skew theta
[INFO] [stdout] 222 |     pub fn new(n: usize, theta: f64) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 240 |     fn zeta(n: usize, theta: f64) -> f64 {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 245 |     pub fn next<R: Rng>(&self, rng: &mut R) -> usize {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `next_key_index` is never used
[INFO] [stdout]    --> benches/measurement_harness.rs:288:8
[INFO] [stdout]     |
[INFO] [stdout] 288 | pub fn next_key_index<R: Rng>(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BenchStats` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:312:12
[INFO] [stdout]     |
[INFO] [stdout] 312 | pub struct BenchStats {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BenchResults` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:327:12
[INFO] [stdout]     |
[INFO] [stdout] 327 | pub struct BenchResults {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LatencyStats` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:340:12
[INFO] [stdout]     |
[INFO] [stdout] 340 | pub struct LatencyStats {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_sorted` is never used
[INFO] [stdout]    --> benches/measurement_harness.rs:352:12
[INFO] [stdout]     |
[INFO] [stdout] 350 | impl LatencyStats {
[INFO] [stdout]     | ----------------- associated function in this implementation
[INFO] [stdout] 351 |     /// Calculate latency stats from a sorted slice of microsecond values
[INFO] [stdout] 352 |     pub fn from_sorted(samples: &[f64]) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `HardwareInfo` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:382:12
[INFO] [stdout]     |
[INFO] [stdout] 382 | pub struct HardwareInfo {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `print_summary`, and `to_json` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:402:12
[INFO] [stdout]     |
[INFO] [stdout] 400 | impl BenchStats {
[INFO] [stdout]     | --------------- associated items in this implementation
[INFO] [stdout] 401 |     /// Create new benchmark stats
[INFO] [stdout] 402 |     pub fn new(
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 436 |     pub fn print_summary(&self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 457 |     pub fn to_json(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `preload`, `run_point_reads`, `run_writes`, and `run_scans` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:508:12
[INFO] [stdout]     |
[INFO] [stdout] 472 | impl DurableStorageHarness {
[INFO] [stdout]     | -------------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 508 |     pub fn preload(&self, config: &BenchConfig) -> anyhow::Result<Duration> {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 534 |     pub fn run_point_reads(&self, config: &BenchConfig) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 584 |     pub fn run_writes(&self, config: &BenchConfig) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 617 |     pub fn run_scans(&self, config: &BenchConfig, scan_size: usize) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `YcsbWorkload` is never used
[INFO] [stdout]    --> benches/measurement_harness.rs:653:10
[INFO] [stdout]     |
[INFO] [stdout] 653 | pub enum YcsbWorkload {
[INFO] [stdout]     |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `read_ratio`, `update_ratio`, `scan_ratio`, and `insert_ratio` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:670:12
[INFO] [stdout]     |
[INFO] [stdout] 668 | impl YcsbWorkload {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] 669 |     /// Get the read ratio for this workload
[INFO] [stdout] 670 |     pub fn read_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 682 |     pub fn update_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 694 |     pub fn scan_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 702 |     pub fn insert_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]   --> benches/measurement_harness.rs:43:5
[INFO] [stdout]    |
[INFO] [stdout] 43 | use std::collections::HashMap;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::*`
[INFO] [stdout]    --> benches/measurement_harness.rs:717:9
[INFO] [stdout]     |
[INFO] [stdout] 717 |     use super::*;
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SMALL_DATASET` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:53:11
[INFO] [stdout]    |
[INFO] [stdout] 53 | pub const SMALL_DATASET: usize = 10_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEDIUM_DATASET` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:54:11
[INFO] [stdout]    |
[INFO] [stdout] 54 | pub const MEDIUM_DATASET: usize = 1_000_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE_DATASET` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:55:11
[INFO] [stdout]    |
[INFO] [stdout] 55 | pub const LARGE_DATASET: usize = 10_000_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_KEY_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:58:11
[INFO] [stdout]    |
[INFO] [stdout] 58 | pub const DEFAULT_KEY_SIZE: usize = 16;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SMALL_VALUE_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:59:11
[INFO] [stdout]    |
[INFO] [stdout] 59 | pub const SMALL_VALUE_SIZE: usize = 100;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEDIUM_VALUE_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:60:11
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub const MEDIUM_VALUE_SIZE: usize = 1_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE_VALUE_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:61:11
[INFO] [stdout]    |
[INFO] [stdout] 61 | pub const LARGE_VALUE_SIZE: usize = 10_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ZIPF_THETA` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:64:11
[INFO] [stdout]    |
[INFO] [stdout] 64 | pub const ZIPF_THETA: f64 = 0.99;
[INFO] [stdout]    |           ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_WARMUP_OPS` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:67:11
[INFO] [stdout]    |
[INFO] [stdout] 67 | pub const DEFAULT_WARMUP_OPS: usize = 1_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_MEASUREMENT_OPS` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:68:11
[INFO] [stdout]    |
[INFO] [stdout] 68 | pub const DEFAULT_MEASUREMENT_OPS: usize = 10_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Distribution` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:72:10
[INFO] [stdout]    |
[INFO] [stdout] 72 | pub enum Distribution {
[INFO] [stdout]    |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `SyncMode` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:89:10
[INFO] [stdout]    |
[INFO] [stdout] 89 | pub enum SyncMode {
[INFO] [stdout]    |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BenchConfig` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:106:12
[INFO] [stdout]     |
[INFO] [stdout] 106 | pub struct BenchConfig {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:145:12
[INFO] [stdout]     |
[INFO] [stdout] 143 | impl BenchConfig {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout] 144 |     /// Create config for small dataset
[INFO] [stdout] 145 |     pub fn small() -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 153 |     pub fn large() -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 161 |     pub fn with_uniform(mut self) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 167 |     pub fn with_sequential(mut self) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 173 |     pub fn with_value_size(mut self, size: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 179 |     pub fn with_sync_mode(mut self, mode: SyncMode) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 185 |     pub fn with_threads(mut self, n: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 191 |     pub fn with_dataset_size(mut self, size: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 197 |     pub fn with_measurement_ops(mut self, ops: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ZipfianGenerator` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:211:12
[INFO] [stdout]     |
[INFO] [stdout] 211 | pub struct ZipfianGenerator {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `zeta`, and `next` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:222:12
[INFO] [stdout]     |
[INFO] [stdout] 220 | impl ZipfianGenerator {
[INFO] [stdout]     | --------------------- associated items in this implementation
[INFO] [stdout] 221 |     /// Create a new Zipfian generator for n items with skew theta
[INFO] [stdout] 222 |     pub fn new(n: usize, theta: f64) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 240 |     fn zeta(n: usize, theta: f64) -> f64 {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 245 |     pub fn next<R: Rng>(&self, rng: &mut R) -> usize {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `next_key_index` is never used
[INFO] [stdout]    --> benches/measurement_harness.rs:288:8
[INFO] [stdout]     |
[INFO] [stdout] 288 | pub fn next_key_index<R: Rng>(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BenchStats` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:312:12
[INFO] [stdout]     |
[INFO] [stdout] 312 | pub struct BenchStats {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BenchResults` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:327:12
[INFO] [stdout]     |
[INFO] [stdout] 327 | pub struct BenchResults {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LatencyStats` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:340:12
[INFO] [stdout]     |
[INFO] [stdout] 340 | pub struct LatencyStats {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_sorted` is never used
[INFO] [stdout]    --> benches/measurement_harness.rs:352:12
[INFO] [stdout]     |
[INFO] [stdout] 350 | impl LatencyStats {
[INFO] [stdout]     | ----------------- associated function in this implementation
[INFO] [stdout] 351 |     /// Calculate latency stats from a sorted slice of microsecond values
[INFO] [stdout] 352 |     pub fn from_sorted(samples: &[f64]) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `HardwareInfo` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:382:12
[INFO] [stdout]     |
[INFO] [stdout] 382 | pub struct HardwareInfo {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `print_summary`, and `to_json` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:402:12
[INFO] [stdout]     |
[INFO] [stdout] 400 | impl BenchStats {
[INFO] [stdout]     | --------------- associated items in this implementation
[INFO] [stdout] 401 |     /// Create new benchmark stats
[INFO] [stdout] 402 |     pub fn new(
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 436 |     pub fn print_summary(&self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 457 |     pub fn to_json(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DurableStorageHarness` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:467:12
[INFO] [stdout]     |
[INFO] [stdout] 467 | pub struct DurableStorageHarness {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:474:12
[INFO] [stdout]     |
[INFO] [stdout] 472 | impl DurableStorageHarness {
[INFO] [stdout]     | -------------------------- associated items in this implementation
[INFO] [stdout] 473 |     /// Create a new harness with default configuration
[INFO] [stdout] 474 |     pub fn new() -> anyhow::Result<Self> {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 483 |     pub fn with_config(enable_ordered_index: bool, enable_group_commit: bool) -> anyhow::Result<Self> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 498 |     pub fn storage(&self) -> &DurableStorage {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 503 |     pub fn set_sync_mode(&self, mode: SyncMode) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 508 |     pub fn preload(&self, config: &BenchConfig) -> anyhow::Result<Duration> {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 534 |     pub fn run_point_reads(&self, config: &BenchConfig) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 584 |     pub fn run_writes(&self, config: &BenchConfig) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 617 |     pub fn run_scans(&self, config: &BenchConfig, scan_size: usize) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `YcsbWorkload` is never used
[INFO] [stdout]    --> benches/measurement_harness.rs:653:10
[INFO] [stdout]     |
[INFO] [stdout] 653 | pub enum YcsbWorkload {
[INFO] [stdout]     |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `read_ratio`, `update_ratio`, `scan_ratio`, and `insert_ratio` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:670:12
[INFO] [stdout]     |
[INFO] [stdout] 668 | impl YcsbWorkload {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] 669 |     /// Get the read ratio for this workload
[INFO] [stdout] 670 |     pub fn read_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 682 |     pub fn update_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 694 |     pub fn scan_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 702 |     pub fn insert_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `std::alloc::GlobalAlloc::alloc` is unsafe and requires unsafe block
[INFO] [stdout]   --> benches/bench_memory.rs:49:19
[INFO] [stdout]    |
[INFO] [stdout] 49 |         let ptr = System.alloc(layout);
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]    |
[INFO] [stdout]    = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] note: an unsafe function restricts its caller, but its body is safe by default
[INFO] [stdout]   --> benches/bench_memory.rs:48:5
[INFO] [stdout]    |
[INFO] [stdout] 48 |     unsafe fn alloc(&self, layout: Layout) -> *mut u8 {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout]    = note: `#[warn(unsafe_op_in_unsafe_fn)]` (part of `#[warn(rust_2024_compatibility)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `std::alloc::GlobalAlloc::dealloc` is unsafe and requires unsafe block
[INFO] [stdout]   --> benches/bench_memory.rs:58:9
[INFO] [stdout]    |
[INFO] [stdout] 58 |         System.dealloc(ptr, layout);
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]    |
[INFO] [stdout]    = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] note: an unsafe function restricts its caller, but its body is safe by default
[INFO] [stdout]   --> benches/bench_memory.rs:56:5
[INFO] [stdout]    |
[INFO] [stdout] 56 |     unsafe fn dealloc(&self, ptr: *mut u8, layout: Layout) {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning[E0133]: call to unsafe function `std::alloc::GlobalAlloc::realloc` is unsafe and requires unsafe block
[INFO] [stdout]   --> benches/bench_memory.rs:62:23
[INFO] [stdout]    |
[INFO] [stdout] 62 |         let new_ptr = System.realloc(ptr, layout, new_size);
[INFO] [stdout]    |                       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ call to unsafe function
[INFO] [stdout]    |
[INFO] [stdout]    = note: consult the function's documentation for information on how to avoid undefined behavior
[INFO] [stdout] note: an unsafe function restricts its caller, but its body is safe by default
[INFO] [stdout]   --> benches/bench_memory.rs:61:5
[INFO] [stdout]    |
[INFO] [stdout] 61 |     unsafe fn realloc(&self, ptr: *mut u8, layout: Layout, new_size: usize) -> *mut u8 {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2024/unsafe-op-in-unsafe-fn.html>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]   --> benches/measurement_harness.rs:43:5
[INFO] [stdout]    |
[INFO] [stdout] 43 | use std::collections::HashMap;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::*`
[INFO] [stdout]    --> benches/measurement_harness.rs:717:9
[INFO] [stdout]     |
[INFO] [stdout] 717 |     use super::*;
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TrackingAllocator` is never constructed
[INFO] [stdout]   --> benches/bench_memory.rs:43:8
[INFO] [stdout]    |
[INFO] [stdout] 43 | struct TrackingAllocator;
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `ALLOCATED` is never used
[INFO] [stdout]   --> benches/bench_memory.rs:45:8
[INFO] [stdout]    |
[INFO] [stdout] 45 | static ALLOCATED: AtomicUsize = AtomicUsize::new(0);
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_allocated_bytes` is never used
[INFO] [stdout]   --> benches/bench_memory.rs:75:4
[INFO] [stdout]    |
[INFO] [stdout] 75 | fn get_allocated_bytes() -> usize {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SMALL_DATASET` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:53:11
[INFO] [stdout]    |
[INFO] [stdout] 53 | pub const SMALL_DATASET: usize = 10_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEDIUM_DATASET` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:54:11
[INFO] [stdout]    |
[INFO] [stdout] 54 | pub const MEDIUM_DATASET: usize = 1_000_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE_DATASET` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:55:11
[INFO] [stdout]    |
[INFO] [stdout] 55 | pub const LARGE_DATASET: usize = 10_000_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_KEY_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:58:11
[INFO] [stdout]    |
[INFO] [stdout] 58 | pub const DEFAULT_KEY_SIZE: usize = 16;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SMALL_VALUE_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:59:11
[INFO] [stdout]    |
[INFO] [stdout] 59 | pub const SMALL_VALUE_SIZE: usize = 100;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEDIUM_VALUE_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:60:11
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub const MEDIUM_VALUE_SIZE: usize = 1_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE_VALUE_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:61:11
[INFO] [stdout]    |
[INFO] [stdout] 61 | pub const LARGE_VALUE_SIZE: usize = 10_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ZIPF_THETA` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:64:11
[INFO] [stdout]    |
[INFO] [stdout] 64 | pub const ZIPF_THETA: f64 = 0.99;
[INFO] [stdout]    |           ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_WARMUP_OPS` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:67:11
[INFO] [stdout]    |
[INFO] [stdout] 67 | pub const DEFAULT_WARMUP_OPS: usize = 1_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_MEASUREMENT_OPS` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:68:11
[INFO] [stdout]    |
[INFO] [stdout] 68 | pub const DEFAULT_MEASUREMENT_OPS: usize = 10_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Distribution` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:72:10
[INFO] [stdout]    |
[INFO] [stdout] 72 | pub enum Distribution {
[INFO] [stdout]    |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `SyncMode` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:89:10
[INFO] [stdout]    |
[INFO] [stdout] 89 | pub enum SyncMode {
[INFO] [stdout]    |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BenchConfig` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:106:12
[INFO] [stdout]     |
[INFO] [stdout] 106 | pub struct BenchConfig {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:145:12
[INFO] [stdout]     |
[INFO] [stdout] 143 | impl BenchConfig {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout] 144 |     /// Create config for small dataset
[INFO] [stdout] 145 |     pub fn small() -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 153 |     pub fn large() -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 161 |     pub fn with_uniform(mut self) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 167 |     pub fn with_sequential(mut self) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 173 |     pub fn with_value_size(mut self, size: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 179 |     pub fn with_sync_mode(mut self, mode: SyncMode) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 185 |     pub fn with_threads(mut self, n: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 191 |     pub fn with_dataset_size(mut self, size: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 197 |     pub fn with_measurement_ops(mut self, ops: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ZipfianGenerator` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:211:12
[INFO] [stdout]     |
[INFO] [stdout] 211 | pub struct ZipfianGenerator {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `zeta`, and `next` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:222:12
[INFO] [stdout]     |
[INFO] [stdout] 220 | impl ZipfianGenerator {
[INFO] [stdout]     | --------------------- associated items in this implementation
[INFO] [stdout] 221 |     /// Create a new Zipfian generator for n items with skew theta
[INFO] [stdout] 222 |     pub fn new(n: usize, theta: f64) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 240 |     fn zeta(n: usize, theta: f64) -> f64 {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 245 |     pub fn next<R: Rng>(&self, rng: &mut R) -> usize {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `next_key_index` is never used
[INFO] [stdout]    --> benches/measurement_harness.rs:288:8
[INFO] [stdout]     |
[INFO] [stdout] 288 | pub fn next_key_index<R: Rng>(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BenchStats` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:312:12
[INFO] [stdout]     |
[INFO] [stdout] 312 | pub struct BenchStats {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BenchResults` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:327:12
[INFO] [stdout]     |
[INFO] [stdout] 327 | pub struct BenchResults {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LatencyStats` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:340:12
[INFO] [stdout]     |
[INFO] [stdout] 340 | pub struct LatencyStats {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_sorted` is never used
[INFO] [stdout]    --> benches/measurement_harness.rs:352:12
[INFO] [stdout]     |
[INFO] [stdout] 350 | impl LatencyStats {
[INFO] [stdout]     | ----------------- associated function in this implementation
[INFO] [stdout] 351 |     /// Calculate latency stats from a sorted slice of microsecond values
[INFO] [stdout] 352 |     pub fn from_sorted(samples: &[f64]) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `HardwareInfo` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:382:12
[INFO] [stdout]     |
[INFO] [stdout] 382 | pub struct HardwareInfo {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `print_summary`, and `to_json` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:402:12
[INFO] [stdout]     |
[INFO] [stdout] 400 | impl BenchStats {
[INFO] [stdout]     | --------------- associated items in this implementation
[INFO] [stdout] 401 |     /// Create new benchmark stats
[INFO] [stdout] 402 |     pub fn new(
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 436 |     pub fn print_summary(&self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 457 |     pub fn to_json(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DurableStorageHarness` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:467:12
[INFO] [stdout]     |
[INFO] [stdout] 467 | pub struct DurableStorageHarness {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:474:12
[INFO] [stdout]     |
[INFO] [stdout] 472 | impl DurableStorageHarness {
[INFO] [stdout]     | -------------------------- associated items in this implementation
[INFO] [stdout] 473 |     /// Create a new harness with default configuration
[INFO] [stdout] 474 |     pub fn new() -> anyhow::Result<Self> {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 483 |     pub fn with_config(enable_ordered_index: bool, enable_group_commit: bool) -> anyhow::Result<Self> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 498 |     pub fn storage(&self) -> &DurableStorage {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 503 |     pub fn set_sync_mode(&self, mode: SyncMode) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 508 |     pub fn preload(&self, config: &BenchConfig) -> anyhow::Result<Duration> {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 534 |     pub fn run_point_reads(&self, config: &BenchConfig) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 584 |     pub fn run_writes(&self, config: &BenchConfig) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 617 |     pub fn run_scans(&self, config: &BenchConfig, scan_size: usize) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `YcsbWorkload` is never used
[INFO] [stdout]    --> benches/measurement_harness.rs:653:10
[INFO] [stdout]     |
[INFO] [stdout] 653 | pub enum YcsbWorkload {
[INFO] [stdout]     |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `read_ratio`, `update_ratio`, `scan_ratio`, and `insert_ratio` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:670:12
[INFO] [stdout]     |
[INFO] [stdout] 668 | impl YcsbWorkload {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] 669 |     /// Get the read ratio for this workload
[INFO] [stdout] 670 |     pub fn read_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 682 |     pub fn update_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 694 |     pub fn scan_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 702 |     pub fn insert_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] For more information about this error, try `rustc --explain E0133`.
[INFO] [stdout] 
[INFO] [stdout] warning: field `zeta_2` is never read
[INFO] [stdout]    --> benches/measurement_harness.rs:215:5
[INFO] [stdout]     |
[INFO] [stdout] 211 | pub struct ZipfianGenerator {
[INFO] [stdout]     |            ---------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 215 |     zeta_2: f64,
[INFO] [stdout]     |     ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SMALL_DATASET` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:53:11
[INFO] [stdout]    |
[INFO] [stdout] 53 | pub const SMALL_DATASET: usize = 10_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEDIUM_DATASET` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:54:11
[INFO] [stdout]    |
[INFO] [stdout] 54 | pub const MEDIUM_DATASET: usize = 1_000_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE_DATASET` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:55:11
[INFO] [stdout]    |
[INFO] [stdout] 55 | pub const LARGE_DATASET: usize = 10_000_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_KEY_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:58:11
[INFO] [stdout]    |
[INFO] [stdout] 58 | pub const DEFAULT_KEY_SIZE: usize = 16;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SMALL_VALUE_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:59:11
[INFO] [stdout]    |
[INFO] [stdout] 59 | pub const SMALL_VALUE_SIZE: usize = 100;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEDIUM_VALUE_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:60:11
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub const MEDIUM_VALUE_SIZE: usize = 1_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE_VALUE_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:61:11
[INFO] [stdout]    |
[INFO] [stdout] 61 | pub const LARGE_VALUE_SIZE: usize = 10_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ZIPF_THETA` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:64:11
[INFO] [stdout]    |
[INFO] [stdout] 64 | pub const ZIPF_THETA: f64 = 0.99;
[INFO] [stdout]    |           ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_WARMUP_OPS` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:67:11
[INFO] [stdout]    |
[INFO] [stdout] 67 | pub const DEFAULT_WARMUP_OPS: usize = 1_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_MEASUREMENT_OPS` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:68:11
[INFO] [stdout]    |
[INFO] [stdout] 68 | pub const DEFAULT_MEASUREMENT_OPS: usize = 10_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `SyncMode` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:89:10
[INFO] [stdout]    |
[INFO] [stdout] 89 | pub enum SyncMode {
[INFO] [stdout]    |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BenchConfig` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:106:12
[INFO] [stdout]     |
[INFO] [stdout] 106 | pub struct BenchConfig {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:145:12
[INFO] [stdout]     |
[INFO] [stdout] 143 | impl BenchConfig {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout] 144 |     /// Create config for small dataset
[INFO] [stdout] 145 |     pub fn small() -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 153 |     pub fn large() -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 161 |     pub fn with_uniform(mut self) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 167 |     pub fn with_sequential(mut self) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 173 |     pub fn with_value_size(mut self, size: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 179 |     pub fn with_sync_mode(mut self, mode: SyncMode) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 185 |     pub fn with_threads(mut self, n: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 191 |     pub fn with_dataset_size(mut self, size: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 197 |     pub fn with_measurement_ops(mut self, ops: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `zeta_2` is never read
[INFO] [stdout]    --> benches/measurement_harness.rs:215:5
[INFO] [stdout]     |
[INFO] [stdout] 211 | pub struct ZipfianGenerator {
[INFO] [stdout]     |            ---------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 215 |     zeta_2: f64,
[INFO] [stdout]     |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BenchStats` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:312:12
[INFO] [stdout]     |
[INFO] [stdout] 312 | pub struct BenchStats {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BenchResults` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:327:12
[INFO] [stdout]     |
[INFO] [stdout] 327 | pub struct BenchResults {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LatencyStats` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:340:12
[INFO] [stdout]     |
[INFO] [stdout] 340 | pub struct LatencyStats {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_sorted` is never used
[INFO] [stdout]    --> benches/measurement_harness.rs:352:12
[INFO] [stdout]     |
[INFO] [stdout] 350 | impl LatencyStats {
[INFO] [stdout]     | ----------------- associated function in this implementation
[INFO] [stdout] 351 |     /// Calculate latency stats from a sorted slice of microsecond values
[INFO] [stdout] 352 |     pub fn from_sorted(samples: &[f64]) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `HardwareInfo` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:382:12
[INFO] [stdout]     |
[INFO] [stdout] 382 | pub struct HardwareInfo {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `print_summary`, and `to_json` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:402:12
[INFO] [stdout]     |
[INFO] [stdout] 400 | impl BenchStats {
[INFO] [stdout]     | --------------- associated items in this implementation
[INFO] [stdout] 401 |     /// Create new benchmark stats
[INFO] [stdout] 402 |     pub fn new(
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 436 |     pub fn print_summary(&self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 457 |     pub fn to_json(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DurableStorageHarness` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:467:12
[INFO] [stdout]     |
[INFO] [stdout] 467 | pub struct DurableStorageHarness {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:474:12
[INFO] [stdout]     |
[INFO] [stdout] 472 | impl DurableStorageHarness {
[INFO] [stdout]     | -------------------------- associated items in this implementation
[INFO] [stdout] 473 |     /// Create a new harness with default configuration
[INFO] [stdout] 474 |     pub fn new() -> anyhow::Result<Self> {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 483 |     pub fn with_config(enable_ordered_index: bool, enable_group_commit: bool) -> anyhow::Result<Self> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 498 |     pub fn storage(&self) -> &DurableStorage {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 503 |     pub fn set_sync_mode(&self, mode: SyncMode) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 508 |     pub fn preload(&self, config: &BenchConfig) -> anyhow::Result<Duration> {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 534 |     pub fn run_point_reads(&self, config: &BenchConfig) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 584 |     pub fn run_writes(&self, config: &BenchConfig) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 617 |     pub fn run_scans(&self, config: &BenchConfig, scan_size: usize) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `YcsbWorkload` is never used
[INFO] [stdout]    --> benches/measurement_harness.rs:653:10
[INFO] [stdout]     |
[INFO] [stdout] 653 | pub enum YcsbWorkload {
[INFO] [stdout]     |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `read_ratio`, `update_ratio`, `scan_ratio`, and `insert_ratio` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:670:12
[INFO] [stdout]     |
[INFO] [stdout] 668 | impl YcsbWorkload {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] 669 |     /// Get the read ratio for this workload
[INFO] [stdout] 670 |     pub fn read_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 682 |     pub fn update_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 694 |     pub fn scan_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 702 |     pub fn insert_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SMALL_DATASET` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:53:11
[INFO] [stdout]    |
[INFO] [stdout] 53 | pub const SMALL_DATASET: usize = 10_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEDIUM_DATASET` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:54:11
[INFO] [stdout]    |
[INFO] [stdout] 54 | pub const MEDIUM_DATASET: usize = 1_000_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE_DATASET` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:55:11
[INFO] [stdout]    |
[INFO] [stdout] 55 | pub const LARGE_DATASET: usize = 10_000_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_KEY_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:58:11
[INFO] [stdout]    |
[INFO] [stdout] 58 | pub const DEFAULT_KEY_SIZE: usize = 16;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SMALL_VALUE_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:59:11
[INFO] [stdout]    |
[INFO] [stdout] 59 | pub const SMALL_VALUE_SIZE: usize = 100;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEDIUM_VALUE_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:60:11
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub const MEDIUM_VALUE_SIZE: usize = 1_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE_VALUE_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:61:11
[INFO] [stdout]    |
[INFO] [stdout] 61 | pub const LARGE_VALUE_SIZE: usize = 10_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ZIPF_THETA` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:64:11
[INFO] [stdout]    |
[INFO] [stdout] 64 | pub const ZIPF_THETA: f64 = 0.99;
[INFO] [stdout]    |           ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_WARMUP_OPS` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:67:11
[INFO] [stdout]    |
[INFO] [stdout] 67 | pub const DEFAULT_WARMUP_OPS: usize = 1_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_MEASUREMENT_OPS` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:68:11
[INFO] [stdout]    |
[INFO] [stdout] 68 | pub const DEFAULT_MEASUREMENT_OPS: usize = 10_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Distribution` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:72:10
[INFO] [stdout]    |
[INFO] [stdout] 72 | pub enum Distribution {
[INFO] [stdout]    |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `SyncMode` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:89:10
[INFO] [stdout]    |
[INFO] [stdout] 89 | pub enum SyncMode {
[INFO] [stdout]    |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BenchConfig` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:106:12
[INFO] [stdout]     |
[INFO] [stdout] 106 | pub struct BenchConfig {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:145:12
[INFO] [stdout]     |
[INFO] [stdout] 143 | impl BenchConfig {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout] 144 |     /// Create config for small dataset
[INFO] [stdout] 145 |     pub fn small() -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 153 |     pub fn large() -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 161 |     pub fn with_uniform(mut self) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 167 |     pub fn with_sequential(mut self) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 173 |     pub fn with_value_size(mut self, size: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 179 |     pub fn with_sync_mode(mut self, mode: SyncMode) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 185 |     pub fn with_threads(mut self, n: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 191 |     pub fn with_dataset_size(mut self, size: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 197 |     pub fn with_measurement_ops(mut self, ops: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ZipfianGenerator` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:211:12
[INFO] [stdout]     |
[INFO] [stdout] 211 | pub struct ZipfianGenerator {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `zeta`, and `next` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:222:12
[INFO] [stdout]     |
[INFO] [stdout] 220 | impl ZipfianGenerator {
[INFO] [stdout]     | --------------------- associated items in this implementation
[INFO] [stdout] 221 |     /// Create a new Zipfian generator for n items with skew theta
[INFO] [stdout] 222 |     pub fn new(n: usize, theta: f64) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 240 |     fn zeta(n: usize, theta: f64) -> f64 {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 245 |     pub fn next<R: Rng>(&self, rng: &mut R) -> usize {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `next_key_index` is never used
[INFO] [stdout]    --> benches/measurement_harness.rs:288:8
[INFO] [stdout]     |
[INFO] [stdout] 288 | pub fn next_key_index<R: Rng>(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BenchStats` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:312:12
[INFO] [stdout]     |
[INFO] [stdout] 312 | pub struct BenchStats {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BenchResults` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:327:12
[INFO] [stdout]     |
[INFO] [stdout] 327 | pub struct BenchResults {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LatencyStats` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:340:12
[INFO] [stdout]     |
[INFO] [stdout] 340 | pub struct LatencyStats {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_sorted` is never used
[INFO] [stdout]    --> benches/measurement_harness.rs:352:12
[INFO] [stdout]     |
[INFO] [stdout] 350 | impl LatencyStats {
[INFO] [stdout]     | ----------------- associated function in this implementation
[INFO] [stdout] 351 |     /// Calculate latency stats from a sorted slice of microsecond values
[INFO] [stdout] 352 |     pub fn from_sorted(samples: &[f64]) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `HardwareInfo` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:382:12
[INFO] [stdout]     |
[INFO] [stdout] 382 | pub struct HardwareInfo {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `print_summary`, and `to_json` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:402:12
[INFO] [stdout]     |
[INFO] [stdout] 400 | impl BenchStats {
[INFO] [stdout]     | --------------- associated items in this implementation
[INFO] [stdout] 401 |     /// Create new benchmark stats
[INFO] [stdout] 402 |     pub fn new(
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 436 |     pub fn print_summary(&self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 457 |     pub fn to_json(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DurableStorageHarness` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:467:12
[INFO] [stdout]     |
[INFO] [stdout] 467 | pub struct DurableStorageHarness {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:474:12
[INFO] [stdout]     |
[INFO] [stdout] 472 | impl DurableStorageHarness {
[INFO] [stdout]     | -------------------------- associated items in this implementation
[INFO] [stdout] 473 |     /// Create a new harness with default configuration
[INFO] [stdout] 474 |     pub fn new() -> anyhow::Result<Self> {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 483 |     pub fn with_config(enable_ordered_index: bool, enable_group_commit: bool) -> anyhow::Result<Self> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 498 |     pub fn storage(&self) -> &DurableStorage {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 503 |     pub fn set_sync_mode(&self, mode: SyncMode) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 508 |     pub fn preload(&self, config: &BenchConfig) -> anyhow::Result<Duration> {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 534 |     pub fn run_point_reads(&self, config: &BenchConfig) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 584 |     pub fn run_writes(&self, config: &BenchConfig) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 617 |     pub fn run_scans(&self, config: &BenchConfig, scan_size: usize) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `YcsbWorkload` is never used
[INFO] [stdout]    --> benches/measurement_harness.rs:653:10
[INFO] [stdout]     |
[INFO] [stdout] 653 | pub enum YcsbWorkload {
[INFO] [stdout]     |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `read_ratio`, `update_ratio`, `scan_ratio`, and `insert_ratio` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:670:12
[INFO] [stdout]     |
[INFO] [stdout] 668 | impl YcsbWorkload {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] 669 |     /// Get the read ratio for this workload
[INFO] [stdout] 670 |     pub fn read_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 682 |     pub fn update_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 694 |     pub fn scan_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 702 |     pub fn insert_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `keys`
[INFO] [stdout]    --> src/dirty_tracking.rs:542:22
[INFO] [stdout]     |
[INFO] [stdout] 542 |         let (_epoch, keys) = tracker.advance_epoch();
[INFO] [stdout]     |                      ^^^^ help: if this is intentional, prefix it with an underscore: `_keys`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SMALL_DATASET` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:53:11
[INFO] [stdout]    |
[INFO] [stdout] 53 | pub const SMALL_DATASET: usize = 10_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEDIUM_DATASET` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:54:11
[INFO] [stdout]    |
[INFO] [stdout] 54 | pub const MEDIUM_DATASET: usize = 1_000_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE_DATASET` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:55:11
[INFO] [stdout]    |
[INFO] [stdout] 55 | pub const LARGE_DATASET: usize = 10_000_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_KEY_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:58:11
[INFO] [stdout]    |
[INFO] [stdout] 58 | pub const DEFAULT_KEY_SIZE: usize = 16;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SMALL_VALUE_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:59:11
[INFO] [stdout]    |
[INFO] [stdout] 59 | pub const SMALL_VALUE_SIZE: usize = 100;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEDIUM_VALUE_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:60:11
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub const MEDIUM_VALUE_SIZE: usize = 1_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE_VALUE_SIZE` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:61:11
[INFO] [stdout]    |
[INFO] [stdout] 61 | pub const LARGE_VALUE_SIZE: usize = 10_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ZIPF_THETA` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:64:11
[INFO] [stdout]    |
[INFO] [stdout] 64 | pub const ZIPF_THETA: f64 = 0.99;
[INFO] [stdout]    |           ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_WARMUP_OPS` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:67:11
[INFO] [stdout]    |
[INFO] [stdout] 67 | pub const DEFAULT_WARMUP_OPS: usize = 1_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DEFAULT_MEASUREMENT_OPS` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:68:11
[INFO] [stdout]    |
[INFO] [stdout] 68 | pub const DEFAULT_MEASUREMENT_OPS: usize = 10_000;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Distribution` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:72:10
[INFO] [stdout]    |
[INFO] [stdout] 72 | pub enum Distribution {
[INFO] [stdout]    |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `SyncMode` is never used
[INFO] [stdout]   --> benches/measurement_harness.rs:89:10
[INFO] [stdout]    |
[INFO] [stdout] 89 | pub enum SyncMode {
[INFO] [stdout]    |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BenchConfig` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:106:12
[INFO] [stdout]     |
[INFO] [stdout] 106 | pub struct BenchConfig {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:145:12
[INFO] [stdout]     |
[INFO] [stdout] 143 | impl BenchConfig {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout] 144 |     /// Create config for small dataset
[INFO] [stdout] 145 |     pub fn small() -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 153 |     pub fn large() -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 161 |     pub fn with_uniform(mut self) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 167 |     pub fn with_sequential(mut self) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 173 |     pub fn with_value_size(mut self, size: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 179 |     pub fn with_sync_mode(mut self, mode: SyncMode) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 185 |     pub fn with_threads(mut self, n: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 191 |     pub fn with_dataset_size(mut self, size: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 197 |     pub fn with_measurement_ops(mut self, ops: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ZipfianGenerator` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:211:12
[INFO] [stdout]     |
[INFO] [stdout] 211 | pub struct ZipfianGenerator {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `zeta`, and `next` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:222:12
[INFO] [stdout]     |
[INFO] [stdout] 220 | impl ZipfianGenerator {
[INFO] [stdout]     | --------------------- associated items in this implementation
[INFO] [stdout] 221 |     /// Create a new Zipfian generator for n items with skew theta
[INFO] [stdout] 222 |     pub fn new(n: usize, theta: f64) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 240 |     fn zeta(n: usize, theta: f64) -> f64 {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 245 |     pub fn next<R: Rng>(&self, rng: &mut R) -> usize {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `next_key_index` is never used
[INFO] [stdout]    --> benches/measurement_harness.rs:288:8
[INFO] [stdout]     |
[INFO] [stdout] 288 | pub fn next_key_index<R: Rng>(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BenchStats` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:312:12
[INFO] [stdout]     |
[INFO] [stdout] 312 | pub struct BenchStats {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BenchResults` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:327:12
[INFO] [stdout]     |
[INFO] [stdout] 327 | pub struct BenchResults {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LatencyStats` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:340:12
[INFO] [stdout]     |
[INFO] [stdout] 340 | pub struct LatencyStats {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from_sorted` is never used
[INFO] [stdout]    --> benches/measurement_harness.rs:352:12
[INFO] [stdout]     |
[INFO] [stdout] 350 | impl LatencyStats {
[INFO] [stdout]     | ----------------- associated function in this implementation
[INFO] [stdout] 351 |     /// Calculate latency stats from a sorted slice of microsecond values
[INFO] [stdout] 352 |     pub fn from_sorted(samples: &[f64]) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `HardwareInfo` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:382:12
[INFO] [stdout]     |
[INFO] [stdout] 382 | pub struct HardwareInfo {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `print_summary`, and `to_json` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:402:12
[INFO] [stdout]     |
[INFO] [stdout] 400 | impl BenchStats {
[INFO] [stdout]     | --------------- associated items in this implementation
[INFO] [stdout] 401 |     /// Create new benchmark stats
[INFO] [stdout] 402 |     pub fn new(
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 436 |     pub fn print_summary(&self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 457 |     pub fn to_json(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DurableStorageHarness` is never constructed
[INFO] [stdout]    --> benches/measurement_harness.rs:467:12
[INFO] [stdout]     |
[INFO] [stdout] 467 | pub struct DurableStorageHarness {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:474:12
[INFO] [stdout]     |
[INFO] [stdout] 472 | impl DurableStorageHarness {
[INFO] [stdout]     | -------------------------- associated items in this implementation
[INFO] [stdout] 473 |     /// Create a new harness with default configuration
[INFO] [stdout] 474 |     pub fn new() -> anyhow::Result<Self> {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 483 |     pub fn with_config(enable_ordered_index: bool, enable_group_commit: bool) -> anyhow::Result<Self> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 498 |     pub fn storage(&self) -> &DurableStorage {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 503 |     pub fn set_sync_mode(&self, mode: SyncMode) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 508 |     pub fn preload(&self, config: &BenchConfig) -> anyhow::Result<Duration> {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 534 |     pub fn run_point_reads(&self, config: &BenchConfig) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 584 |     pub fn run_writes(&self, config: &BenchConfig) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 617 |     pub fn run_scans(&self, config: &BenchConfig, scan_size: usize) -> anyhow::Result<BenchStats> {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `YcsbWorkload` is never used
[INFO] [stdout]    --> benches/measurement_harness.rs:653:10
[INFO] [stdout]     |
[INFO] [stdout] 653 | pub enum YcsbWorkload {
[INFO] [stdout]     |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `read_ratio`, `update_ratio`, `scan_ratio`, and `insert_ratio` are never used
[INFO] [stdout]    --> benches/measurement_harness.rs:670:12
[INFO] [stdout]     |
[INFO] [stdout] 668 | impl YcsbWorkload {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] 669 |     /// Get the read ratio for this workload
[INFO] [stdout] 670 |     pub fn read_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 682 |     pub fn update_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 694 |     pub fn scan_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 702 |     pub fn insert_ratio(&self) -> f64 {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> benches/bench_recovery.rs:271:17
[INFO] [stdout]     |
[INFO] [stdout] 271 |                 black_box(result);
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 271 |                 let _ = black_box(result);
[INFO] [stdout]     |                 +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]    --> src/rl_workload.rs:668:13
[INFO] [stdout]     |
[INFO] [stdout] 668 |         for i in 0..NUM_ARMS {
[INFO] [stdout]     |             ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config1`
[INFO] [stdout]    --> src/rl_workload.rs:686:13
[INFO] [stdout]     |
[INFO] [stdout] 686 |         let config1 = classifier.current_config();
[INFO] [stdout]     |             ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_config1`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/vectorized_scan.rs:1287:13
[INFO] [stdout]      |
[INFO] [stdout] 1287 |         let mut v = ColumnVector::Int64(vec![1, 2, 3, 4, 5]);
[INFO] [stdout]      |             ----^
[INFO] [stdout]      |             |
[INFO] [stdout]      |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `guard`
[INFO] [stdout]    --> src/concurrent_art.rs:421:61
[INFO] [stdout]     |
[INFO] [stdout] 421 |     pub fn add_child(&self, key: u8, child: Owned<ArtNode>, guard: &Guard) -> bool {
[INFO] [stdout]     |                                                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_guard`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/sstable/block.rs:496:13
[INFO] [stdout]     |
[INFO] [stdout] 496 |         let mut iter = self.seek(key);
[INFO] [stdout]     |             ----^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `largest_key`
[INFO] [stdout]    --> src/sstable/builder.rs:278:35
[INFO] [stdout]     |
[INFO] [stdout] 278 |     fn add_index_entry(&mut self, largest_key: &[u8]) -> std::io::Result<()> {
[INFO] [stdout]     |                                   ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_largest_key`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `deficit` and `pending_count` are never read
[INFO] [stdout]    --> src/admission_control.rs:259:5
[INFO] [stdout]     |
[INFO] [stdout] 251 | pub struct TenantQuota {
[INFO] [stdout]     |            ----------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 259 |     deficit: AtomicI64,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout] 260 |     /// Queue of pending requests
[INFO] [stdout] 261 |     pending_count: AtomicU64,
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `dimension` and `metric` are never read
[INFO] [stdout]   --> src/ffi.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 37 | struct CollectionIndex {
[INFO] [stdout]    |        --------------- fields in this struct
[INFO] [stdout] 38 |     index: Arc<HnswIndex>,
[INFO] [stdout] 39 |     dimension: usize,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 40 |     metric: DistanceMetric,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `path` and `our_pid` are never read
[INFO] [stdout]    --> src/lock.rs:606:5
[INFO] [stdout]     |
[INFO] [stdout] 602 | pub struct RwDatabaseLock {
[INFO] [stdout]     |            -------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 606 |     path: PathBuf,
[INFO] [stdout]     |     ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 610 |     our_pid: u32,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `path` is never read
[INFO] [stdout]    --> src/mvcc_concurrent.rs:793:5
[INFO] [stdout]     |
[INFO] [stdout] 791 | pub struct ConcurrentMvcc {
[INFO] [stdout]     |            -------------- field in this struct
[INFO] [stdout] 792 |     /// Path to database
[INFO] [stdout] 793 |     path: PathBuf,
[INFO] [stdout]     |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `path` is never read
[INFO] [stdout]    --> src/wal_fencing.rs:376:5
[INFO] [stdout]     |
[INFO] [stdout] 374 | pub struct FencedWal {
[INFO] [stdout]     |            --------- field in this struct
[INFO] [stdout] 375 |     /// Path to WAL file
[INFO] [stdout] 376 |     path: PathBuf,
[INFO] [stdout]     |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `filter_batch_scalar` is never used
[INFO] [stdout]    --> src/vectorized_scan.rs:649:8
[INFO] [stdout]     |
[INFO] [stdout] 613 | impl SimdVisibilityFilter {
[INFO] [stdout]     | ------------------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 649 |     fn filter_batch_scalar(commit_ts: &[u64], snapshot_ts: u64, out: &mut [bool]) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `config` is never read
[INFO] [stdout]    --> src/io_uring.rs:441:5
[INFO] [stdout]     |
[INFO] [stdout] 439 | pub struct LinuxIoUringBackend {
[INFO] [stdout]     |            ------------------- field in this struct
[INFO] [stdout] 440 |     uring: Option<IoUring>,
[INFO] [stdout] 441 |     config: IoUringConfig,
[INFO] [stdout]     |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `check_uring_available` is never used
[INFO] [stdout]    --> src/io_uring.rs:476:8
[INFO] [stdout]     |
[INFO] [stdout] 450 | impl LinuxIoUringBackend {
[INFO] [stdout]     | ------------------------ associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 476 |     fn check_uring_available() -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RestartPoint` is never constructed
[INFO] [stdout]    --> src/sstable/block.rs:150:8
[INFO] [stdout]     |
[INFO] [stdout] 150 | struct RestartPoint {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `HashBucket` is never constructed
[INFO] [stdout]    --> src/sstable/block.rs:157:8
[INFO] [stdout]     |
[INFO] [stdout] 157 | struct HashBucket {
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `num_hash_buckets` is never read
[INFO] [stdout]    --> src/sstable/block.rs:357:5
[INFO] [stdout]     |
[INFO] [stdout] 349 | pub struct Block {
[INFO] [stdout]     |            ----- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 357 |     num_hash_buckets: usize,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `num_slots` is never read
[INFO] [stdout]    --> src/sstable/filter.rs:418:5
[INFO] [stdout]     |
[INFO] [stdout] 412 | struct RibbonFilterBuilder {
[INFO] [stdout]     |        ------------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 418 |     num_slots: usize,
[INFO] [stdout]     |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `header`, `footer`, and `index` are never read
[INFO] [stdout]    --> src/sstable/table.rs:118:5
[INFO] [stdout]     |
[INFO] [stdout] 110 | pub struct SSTable {
[INFO] [stdout]     |            ------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 118 |     header: Header,
[INFO] [stdout]     |     ^^^^^^
[INFO] [stdout] 119 |     /// Parsed footer with sections
[INFO] [stdout] 120 |     footer: Footer,
[INFO] [stdout]     |     ^^^^^^
[INFO] [stdout] 121 |     /// Index block (cached)
[INFO] [stdout] 122 |     index: Vec<u8>,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `path` is never read
[INFO] [stdout]    --> src/wal_segment.rs:188:5
[INFO] [stdout]     |
[INFO] [stdout] 184 | struct ActiveSegment {
[INFO] [stdout]     |        ------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 188 |     path: PathBuf,
[INFO] [stdout]     |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `config` is never read
[INFO] [stdout]    --> src/compaction_policy.rs:470:5
[INFO] [stdout]     |
[INFO] [stdout] 469 | pub struct UniversalCompactionPicker {
[INFO] [stdout]     |            ------------------------- field in this struct
[INFO] [stdout] 470 |     config: CompactionConfig,
[INFO] [stdout]     |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: comparison is useless due to type limits
[INFO] [stdout]    --> src/epoch_mvcc.rs:851:17
[INFO] [stdout]     |
[INFO] [stdout] 851 |         assert!(gc_stats.versions_removed >= 0);
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_comparisons)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/sstable/table.rs:410:17
[INFO] [stdout]     |
[INFO] [stdout] 410 |     pub fn iter(&self) -> SSTableIterator {
[INFO] [stdout]     |                 ^^^^^     ^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 410 |     pub fn iter(&self) -> SSTableIterator<'_> {
[INFO] [stdout]     |                                          ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/sstable/table.rs:416:9
[INFO] [stdout]     |
[INFO] [stdout] 416 |         &self,
[INFO] [stdout]     |         ^^^^^ the lifetime is elided here
[INFO] [stdout] ...
[INFO] [stdout] 419 |     ) -> RangeIterator {
[INFO] [stdout]     |          ^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 419 |     ) -> RangeIterator<'_> {
[INFO] [stdout]     |                       ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/wal_segment.rs:574:30
[INFO] [stdout]     |
[INFO] [stdout] 574 |     pub fn recovery_iterator(&self, from_lsn: u64) -> RecoveryIterator {
[INFO] [stdout]     |                              ^^^^^                    ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                              |
[INFO] [stdout]     |                              the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 574 |     pub fn recovery_iterator(&self, from_lsn: u64) -> RecoveryIterator<'_> {
[INFO] [stdout]     |                                                                       ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: comparison is useless due to type limits
[INFO] [stdout]    --> src/wal_segment.rs:797:17
[INFO] [stdout]     |
[INFO] [stdout] 797 |         assert!(cleaned >= 0);
[INFO] [stdout]     |                 ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 55s
[INFO] running `Command { std: "docker" "inspect" "1c86760a2446503ce483e9a02e640325c8073e28b211c1632302d3d1ffb1b7e0", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "1c86760a2446503ce483e9a02e640325c8073e28b211c1632302d3d1ffb1b7e0", kill_on_drop: false }`
[INFO] [stdout] 1c86760a2446503ce483e9a02e640325c8073e28b211c1632302d3d1ffb1b7e0
