From 165237bdd1677b475e5aa2e4dd14c561be859e9c Mon Sep 17 00:00:00 2001 From: Arni Hod Date: Mon, 2 Dec 2024 13:10:47 +0200 Subject: [PATCH] chore(starknet_gateway): create bench file for benchmark test --- Cargo.lock | 1 + crates/starknet_gateway/Cargo.toml | 6 +++ .../starknet_gateway/bench/gateway_bench.rs | 37 +++++++++++++++++++ 3 files changed, 44 insertions(+) create mode 100644 crates/starknet_gateway/bench/gateway_bench.rs diff --git a/Cargo.lock b/Cargo.lock index 1c00c629186..c2308f37a70 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -10432,6 +10432,7 @@ dependencies = [ "blockifier", "cairo-lang-sierra-to-casm", "cairo-lang-starknet-classes", + "criterion", "futures", "mempool_test_utils", "mockall", diff --git a/crates/starknet_gateway/Cargo.toml b/crates/starknet_gateway/Cargo.toml index 6420c9ba5e6..8d5999f6810 100644 --- a/crates/starknet_gateway/Cargo.toml +++ b/crates/starknet_gateway/Cargo.toml @@ -39,6 +39,7 @@ validator.workspace = true [dev-dependencies] assert_matches.workspace = true cairo-lang-sierra-to-casm.workspace = true +criterion = { workspace = true, features = ["html_reports"] } mockall.workspace = true mockito.workspace = true num-bigint.workspace = true @@ -49,3 +50,8 @@ rstest.workspace = true starknet_mempool.workspace = true starknet_mempool_types = { workspace = true, features = ["testing"] } tracing-test.workspace = true + +[[bench]] +harness = false +name = "gateway_bench" +path = "bench/gateway_bench.rs" diff --git a/crates/starknet_gateway/bench/gateway_bench.rs b/crates/starknet_gateway/bench/gateway_bench.rs new file mode 100644 index 00000000000..a28f74db34a --- /dev/null +++ b/crates/starknet_gateway/bench/gateway_bench.rs @@ -0,0 +1,37 @@ +//! Benchmark module for the starknet gateway crate. It provides functionalities to benchmark +//! the performance of the gateway service, including declare, deploy account and invoke +//! transactions. +//! +//! There are four benchmark functions in this flow: `declare_benchmark`, +//! `deploy_account_benchmark`, `invoke_benchmark` and `gateway_benchmark` which combines all of the +//! types. Each of the functions measure the performance of the gateway handling randomly created +//! txs of the respective type. +//! +//! Run the benchmarks using `cargo bench --bench gateway_bench`. + +use criterion::{criterion_group, criterion_main, Criterion}; + +pub fn declare_benchmark(c: &mut Criterion) { + c.bench_function("declares", |benchmark| benchmark.iter(|| {})); +} + +pub fn deploy_account_benchmark(c: &mut Criterion) { + c.bench_function("deploy_accounts", |benchmark| benchmark.iter(|| {})); +} + +pub fn invoke_benchmark(c: &mut Criterion) { + c.bench_function("invokes", |benchmark| benchmark.iter(|| {})); +} + +pub fn gateway_benchmark(c: &mut Criterion) { + c.bench_function("all_transaction_types", |benchmark| benchmark.iter(|| {})); +} + +criterion_group!( + benches, + declare_benchmark, + deploy_account_benchmark, + invoke_benchmark, + gateway_benchmark +); +criterion_main!(benches);