feat(bench): add safety number & epoch rotation benchmarks, CI workflow
Add safety_number benchmark to crypto_benchmarks.rs, epoch rotation (propose_self_update + commit) benchmark to mls_operations.rs, expand add_member group sizes to include 100, and add .github/workflows/bench.yml that runs Criterion benchmarks and uploads HTML reports as artifacts.
This commit is contained in:
@@ -62,8 +62,8 @@ fn bench_group_create(c: &mut Criterion) {
|
||||
|
||||
fn bench_add_member(c: &mut Criterion) {
|
||||
let mut group = c.benchmark_group("mls_add_member");
|
||||
// Smaller sizes to keep setup time reasonable
|
||||
for size in [2, 10, 50] {
|
||||
group.sample_size(10);
|
||||
for size in [2, 10, 50, 100] {
|
||||
group.bench_with_input(BenchmarkId::from_parameter(size), &size, |b, &size| {
|
||||
b.iter_batched(
|
||||
|| {
|
||||
@@ -83,6 +83,29 @@ fn bench_add_member(c: &mut Criterion) {
|
||||
group.finish();
|
||||
}
|
||||
|
||||
fn bench_epoch_rotation(c: &mut Criterion) {
|
||||
let mut group = c.benchmark_group("mls_epoch_rotation");
|
||||
group.sample_size(10);
|
||||
for size in [2, 10, 50] {
|
||||
group.bench_with_input(BenchmarkId::from_parameter(size), &size, |b, &size| {
|
||||
b.iter_batched(
|
||||
|| {
|
||||
let (mut creator, members) = setup_group(size);
|
||||
// Propose a self-update to simulate epoch rotation
|
||||
let proposal = creator.propose_self_update().unwrap();
|
||||
(creator, members, proposal)
|
||||
},
|
||||
|(mut creator, _members, _proposal)| {
|
||||
// Commit pending proposals (the self-update) to advance the epoch
|
||||
creator.commit_pending_proposals().unwrap();
|
||||
},
|
||||
BatchSize::SmallInput,
|
||||
);
|
||||
});
|
||||
}
|
||||
group.finish();
|
||||
}
|
||||
|
||||
fn bench_send_message(c: &mut Criterion) {
|
||||
let mut group = c.benchmark_group("mls_send_message");
|
||||
for size in [2, 10, 50] {
|
||||
@@ -127,6 +150,7 @@ criterion_group!(
|
||||
bench_keygen,
|
||||
bench_group_create,
|
||||
bench_add_member,
|
||||
bench_epoch_rotation,
|
||||
bench_send_message,
|
||||
bench_receive_message,
|
||||
);
|
||||
|
||||
Reference in New Issue
Block a user