introduce traits

This commit is contained in:
GroovieGermanikus 2024-03-27 18:00:10 +01:00
parent 4d5b9f23f3
commit fd3fe80336
No known key found for this signature in database
GPG Key ID: 5B6EB831A5CD2015
2 changed files with 61 additions and 27 deletions

View File

@ -100,12 +100,22 @@ async fn main() {
); );
let benchrun_at = SystemTime::now(); let benchrun_at = SystemTime::now();
let bench_impl = BenchRunnerOldBenchImpl { let bench_impl: Box<dyn BenchTrait<Metric>> = if true {
benchrun_at, Box::new(BenchRunnerBench1Impl {
tenant_config: tenant_config.clone(), benchrun_at,
bench_config: bench_config.clone(), tenant_config: tenant_config.clone(),
funded_payer: funded_payer.clone(), bench_config: bench_config.clone(),
size_tx, funded_payer: funded_payer.clone(),
size_tx,
})
} else {
Box::new(BenchRunnerConfirmationRateImpl {
benchrun_at,
tenant_config: tenant_config.clone(),
bench_config: bench_config.clone(),
funded_payer: funded_payer.clone(),
size_tx,
})
}; };
if let Some(postgres_session) = postgres_session.as_ref() { if let Some(postgres_session) = postgres_session.as_ref() {
@ -120,23 +130,8 @@ async fn main() {
} }
let metric = bench_impl.run_bench().await; let metric = bench_impl.run_bench().await;
// let metric = bench::service_adapter1::bench_servicerunner(
// &bench_config,
// tenant_config.rpc_addr.clone(),
// funded_payer.insecure_clone(),
// size_tx,
// )
// .await;
if let Some(postgres_session) = postgres_session.as_ref() { if let Some(postgres_session) = postgres_session.as_ref() {
// let _dbstatus = save_metrics_to_postgres(
// postgres_session,
// &tenant_config,
// &bench_config,
// &metric,
// benchrun_at,
// )
// .await;
let save_result = bench_impl.try_save_results_postgres(&metric, postgres_session).await; let save_result = bench_impl.try_save_results_postgres(&metric, postgres_session).await;
if let Err(err) = save_result { if let Err(err) = save_result {
warn!("Failed to save metrics to postgres (err {:?}) - continue", err); warn!("Failed to save metrics to postgres (err {:?}) - continue", err);
@ -172,17 +167,19 @@ async fn main() {
// R: result // R: result
#[async_trait] #[async_trait]
trait BenchRunner<M> { trait BenchRunner<M>: Send + Sync + 'static {
async fn run_bench(&self) -> M; async fn run_bench(&self) -> M;
} }
trait BenchTrait<M>: BenchRunner<M> + BenchMetricsPostgresSaver<M> {}
// R: result // R: result
#[async_trait] #[async_trait]
trait BenchMetricsPostgresSaver<M> { trait BenchMetricsPostgresSaver<M>: Send + Sync + 'static {
async fn try_save_results_postgres(&self, metric: &M, postgres_session: &PostgresSessionCache) -> anyhow::Result<()>; async fn try_save_results_postgres(&self, metric: &M, postgres_session: &PostgresSessionCache) -> anyhow::Result<()>;
} }
struct BenchRunnerOldBenchImpl { struct BenchRunnerBench1Impl {
pub benchrun_at: SystemTime, pub benchrun_at: SystemTime,
pub tenant_config: TenantConfig, pub tenant_config: TenantConfig,
pub bench_config: BenchConfig, pub bench_config: BenchConfig,
@ -190,8 +187,11 @@ struct BenchRunnerOldBenchImpl {
pub size_tx: TxSize, pub size_tx: TxSize,
} }
impl BenchTrait<Metric> for BenchRunnerBench1Impl {}
#[async_trait] #[async_trait]
impl BenchRunner<Metric> for BenchRunnerOldBenchImpl { impl BenchRunner<Metric> for BenchRunnerBench1Impl {
async fn run_bench(&self) -> Metric { async fn run_bench(&self) -> Metric {
bench::service_adapter1::bench_servicerunner( bench::service_adapter1::bench_servicerunner(
&self.bench_config, &self.bench_config,
@ -202,3 +202,30 @@ impl BenchRunner<Metric> for BenchRunnerOldBenchImpl {
.await .await
} }
} }
impl BenchTrait<Metric> for BenchRunnerConfirmationRateImpl {}
struct BenchRunnerConfirmationRateImpl {
pub benchrun_at: SystemTime,
pub tenant_config: TenantConfig,
pub bench_config: BenchConfig,
pub funded_payer: Arc<Keypair>,
pub size_tx: TxSize,
}
#[async_trait]
impl BenchRunner<Metric> for BenchRunnerConfirmationRateImpl {
async fn run_bench(&self) -> Metric {
bench::service_adapter_new::benchnew_confirmation_rate_servicerunner(
&self.bench_config,
self.tenant_config.rpc_addr.clone(),
self.funded_payer.insecure_clone(),
self.size_tx,
)
.await
}
}

View File

@ -6,7 +6,7 @@ use log::warn;
use postgres_types::ToSql; use postgres_types::ToSql;
use std::time::SystemTime; use std::time::SystemTime;
use async_trait::async_trait; use async_trait::async_trait;
use crate::{BenchMetricsPostgresSaver, BenchRunner, BenchRunnerOldBenchImpl}; use crate::{BenchMetricsPostgresSaver, BenchRunner, BenchRunnerBench1Impl, BenchRunnerConfirmationRateImpl};
#[allow(clippy::upper_case_acronyms)] #[allow(clippy::upper_case_acronyms)]
pub enum BenchRunStatus { pub enum BenchRunStatus {
@ -62,7 +62,7 @@ pub async fn upsert_benchrun_status(
#[async_trait] #[async_trait]
impl BenchMetricsPostgresSaver<Metric> for BenchRunnerOldBenchImpl { impl BenchMetricsPostgresSaver<Metric> for BenchRunnerBench1Impl {
async fn try_save_results_postgres(&self, metric: &Metric, postgres_session: &PostgresSessionCache) -> anyhow::Result<()> { async fn try_save_results_postgres(&self, metric: &Metric, postgres_session: &PostgresSessionCache) -> anyhow::Result<()> {
let metricjson = serde_json::to_value(metric).unwrap(); let metricjson = serde_json::to_value(metric).unwrap();
let values: &[&(dyn ToSql + Sync)] = &[ let values: &[&(dyn ToSql + Sync)] = &[
@ -102,3 +102,10 @@ impl BenchMetricsPostgresSaver<Metric> for BenchRunnerOldBenchImpl {
} }
#[async_trait]
impl BenchMetricsPostgresSaver<Metric> for BenchRunnerConfirmationRateImpl {
async fn try_save_results_postgres(&self, metric: &Metric, postgres_session: &PostgresSessionCache) -> anyhow::Result<()> {
todo!();
}
}