mirror of
https://github.com/hinto-janai/cuprate.git
synced 2025-01-26 04:15:54 +00:00
add more env
tests
This commit is contained in:
parent
c6612a6edf
commit
43262babd7
1 changed files with 49 additions and 8 deletions
|
@ -6,6 +6,7 @@ use criterion::{black_box, criterion_group, criterion_main, Criterion};
|
||||||
use function_name::named;
|
use function_name::named;
|
||||||
|
|
||||||
use cuprate_database::{
|
use cuprate_database::{
|
||||||
|
config::Config,
|
||||||
resize::{page_size, ResizeAlgorithm},
|
resize::{page_size, ResizeAlgorithm},
|
||||||
tables::Outputs,
|
tables::Outputs,
|
||||||
ConcreteEnv, Env, EnvInner, TxRo, TxRw,
|
ConcreteEnv, Env, EnvInner, TxRo, TxRw,
|
||||||
|
@ -17,11 +18,14 @@ use cuprate_database_benchmark::tmp_concrete_env;
|
||||||
criterion_group!(
|
criterion_group!(
|
||||||
benches,
|
benches,
|
||||||
open,
|
open,
|
||||||
|
env_inner,
|
||||||
tx_ro,
|
tx_ro,
|
||||||
tx_rw,
|
tx_rw,
|
||||||
open_tables,
|
open_tables,
|
||||||
open_tables_mut,
|
open_tables_mut,
|
||||||
resize
|
resize,
|
||||||
|
current_map_size,
|
||||||
|
disk_size_bytes,
|
||||||
);
|
);
|
||||||
criterion_main!(benches);
|
criterion_main!(benches);
|
||||||
|
|
||||||
|
@ -29,14 +33,24 @@ criterion_main!(benches);
|
||||||
/// [`Env::open`].
|
/// [`Env::open`].
|
||||||
#[named]
|
#[named]
|
||||||
fn open(c: &mut Criterion) {
|
fn open(c: &mut Criterion) {
|
||||||
|
let tempdir = tempfile::tempdir().unwrap();
|
||||||
|
let config = Config::low_power(Some(tempdir.path().into()));
|
||||||
|
|
||||||
|
c.bench_function(function_name!(), |b| {
|
||||||
|
b.iter_with_large_drop(|| {
|
||||||
|
ConcreteEnv::open(config.clone()).unwrap();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/// [`Env::env_inner`].
|
||||||
|
#[named]
|
||||||
|
fn env_inner(c: &mut Criterion) {
|
||||||
|
let (env, _tempdir) = tmp_concrete_env();
|
||||||
|
|
||||||
c.bench_function(function_name!(), |b| {
|
c.bench_function(function_name!(), |b| {
|
||||||
b.iter(|| {
|
b.iter(|| {
|
||||||
// We don't want `tempfile`'s file destruction code
|
black_box(env.env_inner());
|
||||||
// to overtake the benchmark, so forget the object
|
|
||||||
// so it doesn't get deconstructed.
|
|
||||||
//
|
|
||||||
// FIXME: this might hit file descriptor limits.
|
|
||||||
std::mem::forget(black_box(tmp_concrete_env()));
|
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -101,7 +115,7 @@ fn open_tables_mut(c: &mut Criterion) {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Test `Env` resizes.
|
/// `Env` memory map resizes.
|
||||||
#[named]
|
#[named]
|
||||||
fn resize(c: &mut Criterion) {
|
fn resize(c: &mut Criterion) {
|
||||||
let (env, _tempdir) = tmp_concrete_env();
|
let (env, _tempdir) = tmp_concrete_env();
|
||||||
|
@ -118,3 +132,30 @@ fn resize(c: &mut Criterion) {
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Access current memory map size of the database.
|
||||||
|
#[named]
|
||||||
|
fn current_map_size(c: &mut Criterion) {
|
||||||
|
let (env, _tempdir) = tmp_concrete_env();
|
||||||
|
|
||||||
|
c.bench_function(function_name!(), |b| {
|
||||||
|
b.iter(|| {
|
||||||
|
// This test is only valid for `Env`'s that need to resize manually.
|
||||||
|
if ConcreteEnv::MANUAL_RESIZE {
|
||||||
|
black_box(env.current_map_size());
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Access on-disk size of the database.
|
||||||
|
#[named]
|
||||||
|
fn disk_size_bytes(c: &mut Criterion) {
|
||||||
|
let (env, _tempdir) = tmp_concrete_env();
|
||||||
|
|
||||||
|
c.bench_function(function_name!(), |b| {
|
||||||
|
b.iter(|| {
|
||||||
|
black_box(env.disk_size_bytes()).unwrap();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue