2024-03-28 20:03:05 +00:00
# `cuprate-database-benchmark`
2024-04-22 00:59:38 +00:00
This is a benchmarking suite that allows testing/benchmarking `cuprate-database` with [`criterion` ](https://bheisler.github.io/criterion.rs/book/criterion_rs.html ).
For more information on `cargo bench` and `criterion` :
- https://doc.rust-lang.org/cargo/commands/cargo-bench.html
- https://bheisler.github.io/criterion.rs/book/criterion_rs.html
2024-03-28 20:03:05 +00:00
<!-- Did you know markdown automatically increments number lists, even if they are all 1...? -->
2024-04-22 00:59:38 +00:00
1. [Usage ](#Usage )
2024-03-28 20:03:05 +00:00
1. [File Structure ](#file-structure )
- [`src/` ](#src )
2024-04-22 00:59:38 +00:00
- [`benches/` ](#benches )
2024-03-28 20:03:05 +00:00
2024-04-22 00:59:38 +00:00
# Usage
Ensure the system is as quiet as possible (no background tasks) before starting and during the benchmarks.
2024-03-28 20:03:05 +00:00
2024-04-22 00:59:38 +00:00
To start all benchmarks, run:
2024-03-28 20:03:05 +00:00
```bash
2024-04-22 00:59:38 +00:00
cargo bench --package cuprate-database-benchmarks
2024-03-28 20:03:05 +00:00
```
# File Structure
A quick reference of the structure of the folders & files in `cuprate-database` .
Note that `lib.rs/mod.rs` files are purely for re-exporting/visibility/lints, and contain no code. Each sub-directory has a corresponding `mod.rs` .
## `src/`
The top-level `src/` files.
2024-04-22 00:59:38 +00:00
The actual `cuprate-database-benchmark` library crate is just used as a helper for the benchmarks within `benches/` .
2024-03-28 20:03:05 +00:00
| File | Purpose |
|---------------------|---------|
2024-04-22 00:59:38 +00:00
| `helper.rs` | Helper functions
## `benches/`
The actual benchmarks.
Each file represents some logical benchmark grouping.
| File | Purpose |
|-----------------------|---------|
| `db.rs` | `trait Database{Ro,Rw,Iter}` benchmarks
| `db_multi_thread.rs` | Same as `db.rs` but multi-threaded
| `env.rs` | `trait {Env, EnvInner, TxR{o,w}, Tables[Mut]}` benchmarks
| `env_multi_thread.rs` | Same as `env.rs` but multi-threaded
2024-04-22 01:05:03 +00:00
| `service.rs` | `cuprate_database::service` benchmarks
2024-04-22 00:59:38 +00:00
| `storable.rs` | `trait Storable` benchmarks