use surrealdb::{engine::any::Any, sql::Id, Surreal}; use tokio::{runtime::Runtime, task::JoinSet}; use crate::sdb_benches::sdk::Record; pub struct Read { runtime: &'static Runtime, table_name: String, } impl Read { pub fn new(runtime: &'static Runtime) -> Self { Self { runtime, table_name: format!("table_{}", Id::rand().to_raw()), } } } impl super::Routine for Read { fn setup(&self, client: &'static Surreal, num_ops: usize) { self.runtime.block_on(async { // Spawn one task for each operation let mut tasks = JoinSet::default(); for task_id in 0..num_ops { let table_name = self.table_name.clone(); tasks.spawn(async move { let _: Option = client .create((table_name, task_id as i64)) .content(Record { field: Id::rand(), }) .await .expect("[setup] create record failed") .expect("[setup] the create operation returned None"); }); } while let Some(task) = tasks.join_next().await { task.unwrap(); } }); } fn run(&self, client: &'static Surreal, num_ops: usize) { self.runtime.block_on(async { // Spawn one task for each operation let mut tasks = JoinSet::default(); for task_id in 0..num_ops { let table_name = self.table_name.clone(); tasks.spawn(async move { let _: Option = criterion::black_box( client .select((table_name, task_id as i64)) .await .expect("[run] select operation failed") .expect("[run] the select operation returned None"), ); }); } while let Some(task) = tasks.join_next().await { task.unwrap(); } }); } fn cleanup(&self, client: &'static Surreal, _num_ops: usize) { self.runtime.block_on(async { client .query(format!("REMOVE table {}", self.table_name)) .await .expect("[cleanup] remove table failed") .check() .unwrap(); }); } }