Skip to content

Commit

Permalink
fix(fuzz-tests): avoid to drop in-use database
Browse files Browse the repository at this point in the history
  • Loading branch information
WenyXu committed May 27, 2024
1 parent af486ec commit a07fc2c
Showing 1 changed file with 15 additions and 8 deletions.
23 changes: 15 additions & 8 deletions tests-fuzz/targets/unstable/fuzz_create_table_standalone.rs
Original file line number Diff line number Diff line change
Expand Up @@ -94,11 +94,11 @@ fn generate_create_table_expr<R: Rng + 'static>(rng: &mut R) -> CreateTableExpr
create_table_generator.generate(rng).unwrap()
}

async fn connect_mysql(addr: &str) -> Pool<MySql> {
async fn connect_mysql(addr: &str, database: &str) -> Pool<MySql> {
loop {
match MySqlPoolOptions::new()
.acquire_timeout(Duration::from_secs(30))
.connect(&format!("mysql://{addr}/public"))
.connect(&format!("mysql://{addr}/{database}"))
.await
{
Ok(mysql) => return mysql,
Expand All @@ -109,18 +109,25 @@ async fn connect_mysql(addr: &str) -> Pool<MySql> {
}
}

const FUZZ_TESTS_DATABASE: &str = "fuzz_tests";

async fn execute_unstable_create_table(
unstable_process_controller: Arc<UnstableProcessController>,
rx: watch::Receiver<ProcessState>,
input: FuzzInput,
) -> Result<()> {
let mysql_public = connect_mysql(DEFAULT_MYSQL_URL, "public").await;
let _ = sqlx::query(&format!("CREATE DATABASE {FUZZ_TESTS_DATABASE}"))
.execute(&mysql_public)
.await
.unwrap_or_else(|_| panic!("Failed to create database '{FUZZ_TESTS_DATABASE}'"));
let mysql = connect_mysql(DEFAULT_MYSQL_URL, FUZZ_TESTS_DATABASE).await;

// Starts the unstable process.
let moved_unstable_process_controller = unstable_process_controller.clone();
let handler = tokio::spawn(async move { moved_unstable_process_controller.start().await });
let mut rng = ChaChaRng::seed_from_u64(input.seed);
let mysql = connect_mysql(DEFAULT_MYSQL_URL).await;
let ctx = FuzzContext { greptime: mysql };

let mut table_states = HashMap::new();

for _ in 0..input.num {
Expand Down Expand Up @@ -163,13 +170,13 @@ async fn execute_unstable_create_table(
}

loop {
let sql = "DROP DATABASE IF EXISTS public";
match sqlx::query(sql).execute(&ctx.greptime).await {
let sql = format!("DROP DATABASE IF EXISTS {FUZZ_TESTS_DATABASE}");
match sqlx::query(&sql).execute(&mysql_public).await {
Ok(result) => {
info!("Drop table: {}, result: {result:?}", sql);
info!("Drop database: {}, result: {result:?}", sql);
break;
}
Err(err) => warn!("Failed to drop table: {}, error: {err}", sql),
Err(err) => warn!("Failed to drop database: {}, error: {err}", sql),
}
}
// Cleans up
Expand Down

0 comments on commit a07fc2c

Please sign in to comment.