From b0bf31a097a3099ddbebd801154c8929525894ae Mon Sep 17 00:00:00 2001 From: Vincent Emonet Date: Sat, 23 Dec 2023 13:49:42 +0100 Subject: [PATCH] test: Add massive benchmark for prefix/postfix --- benches/criterion_benchmark.rs | 39 ++++++++++++++++++++++++++++++++++ 1 file changed, 39 insertions(+) diff --git a/benches/criterion_benchmark.rs b/benches/criterion_benchmark.rs index b6bace6..cc7ecce 100644 --- a/benches/criterion_benchmark.rs +++ b/benches/criterion_benchmark.rs @@ -140,6 +140,45 @@ fn trie_benchmark(c: &mut Criterion) { } }); }); + + c.bench_function("trie_massive_prefixes_match", |b| { + let mut t = ptrie::Trie::new(); + let keys = generate_keys(); + for key in &keys { + t.insert(black_box(key.bytes()), black_box(key.clone())); + } + b.iter(|| { + for key in &keys { + assert!(!t.find_prefixes(black_box(key.bytes())).is_empty()); + } + }); + }); + + c.bench_function("trie_massive_longest_prefixes_match", |b| { + let mut t = ptrie::Trie::new(); + let keys = generate_keys(); + for key in &keys { + t.insert(black_box(key.bytes()), black_box(key.clone())); + } + b.iter(|| { + for key in &keys { + assert!(t.find_longest_prefix(black_box(key.bytes())).is_some()); + } + }); + }); + + c.bench_function("trie_massive_postfixes_match", |b| { + let mut t = ptrie::Trie::new(); + let keys = generate_keys(); + for key in &keys { + t.insert(black_box(key.bytes()), black_box(key.clone())); + } + b.iter(|| { + for key in &keys { + assert!(!t.find_postfixes(black_box(key.bytes())).is_empty()); + } + }); + }); } fn hashmap_benchmark(c: &mut Criterion) {