954e2703e2
- Replace all kusama/Kusama references with dicle/Dicle - Rename weight files from ksm_size to dcl_size - Update papi-tests files from ksm to dcl - Remove chain-specs/kusama.json files - cargo check --workspace successful (Finished output) - Update MAINNET_ROADMAP.md: FAZ 8 completed
75 lines
2.4 KiB
Rust
75 lines
2.4 KiB
Rust
// Copyright (C) Parity Technologies (UK) Ltd. and Dijital Kurdistan Tech Institute
|
|
// This file is part of Pezkuwi.
|
|
|
|
// Pezkuwi is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
|
|
// Pezkuwi is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with Pezkuwi. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
//! statement-distribution regression tests
|
|
//!
|
|
//! Statement distribution benchmark based on Dicle parameters and scale.
|
|
|
|
use pezkuwi_subsystem_bench::{
|
|
configuration::TestConfiguration,
|
|
statement::{benchmark_statement_distribution, prepare_test, TestState},
|
|
usage::BenchmarkUsage,
|
|
utils::save_to_file,
|
|
};
|
|
use std::io::Write;
|
|
|
|
const BENCH_COUNT: usize = 50;
|
|
|
|
fn main() -> Result<(), String> {
|
|
let mut messages = vec![];
|
|
let mut config = TestConfiguration::default();
|
|
config.n_cores = 100;
|
|
config.n_validators = 500;
|
|
config.num_blocks = 10;
|
|
config.connectivity = 100;
|
|
config.generate_pov_sizes();
|
|
let state = TestState::new(&config);
|
|
|
|
println!("Benchmarking...");
|
|
let usages: Vec<BenchmarkUsage> = (0..BENCH_COUNT)
|
|
.map(|n| {
|
|
print!("\r[{}{}]", "#".repeat(n), "_".repeat(BENCH_COUNT - n));
|
|
std::io::stdout().flush().unwrap();
|
|
let mut env = prepare_test(&state, false);
|
|
env.runtime().block_on(benchmark_statement_distribution(&mut env, &state))
|
|
})
|
|
.collect();
|
|
println!("\rDone!{}", " ".repeat(BENCH_COUNT));
|
|
|
|
let average_usage = BenchmarkUsage::average(&usages);
|
|
save_to_file(
|
|
"charts/statement-distribution-regression-bench.json",
|
|
average_usage.to_chart_json().map_err(|e| e.to_string())?,
|
|
)
|
|
.map_err(|e| e.to_string())?;
|
|
println!("{}", average_usage);
|
|
|
|
// We expect no variance for received and sent
|
|
// but use 0.001 because we operate with floats
|
|
messages.extend(average_usage.check_network_usage(&[
|
|
("Received from peers", 106.4000, 0.001),
|
|
("Sent to peers", 127.9100, 0.001),
|
|
]));
|
|
messages.extend(average_usage.check_cpu_usage(&[("statement-distribution", 0.0341, 0.1)]));
|
|
|
|
if messages.is_empty() {
|
|
Ok(())
|
|
} else {
|
|
eprintln!("{}", messages.join("\n"));
|
|
Err("Regressions found".to_string())
|
|
}
|
|
}
|