From 6ca524e768b52e24022ffe2d288c6e6add6b3422 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jakub=20Ber=C3=A1nek?= Date: Mon, 17 Jun 2024 16:25:44 +0200 Subject: [PATCH] Use a transaction when applying migrations --- src/db.rs | 23 ++++++++++++++--------- src/main.rs | 2 +- 2 files changed, 15 insertions(+), 10 deletions(-) diff --git a/src/db.rs b/src/db.rs index 35945f11..c74606cf 100644 --- a/src/db.rs +++ b/src/db.rs @@ -151,7 +151,7 @@ fn cert() { make_certificates(); } -pub async fn run_migrations(client: &DbClient) -> anyhow::Result<()> { +pub async fn run_migrations(client: &mut DbClient) -> anyhow::Result<()> { client .execute( "CREATE TABLE IF NOT EXISTS database_versions ( @@ -182,17 +182,22 @@ pub async fn run_migrations(client: &DbClient) -> anyhow::Result<()> { for (idx, migration) in MIGRATIONS.iter().enumerate() { if idx >= migration_idx { - client - .execute(*migration, &[]) + let tx = client + .transaction() + .await + .context("Cannot create migration transactin")?; + tx.execute(*migration, &[]) .await .with_context(|| format!("executing {}th migration", idx))?; - client - .execute( - "UPDATE database_versions SET migration_counter = $1", - &[&(idx as i32 + 1)], - ) + tx.execute( + "UPDATE database_versions SET migration_counter = $1", + &[&(idx as i32 + 1)], + ) + .await + .with_context(|| format!("updating migration counter to {}", idx))?; + tx.commit() .await - .with_context(|| format!("updating migration counter to {}", idx))?; + .context("Cannot commit migration transaction")?; } } diff --git a/src/main.rs b/src/main.rs index 2d59fc87..362977e2 100644 --- a/src/main.rs +++ b/src/main.rs @@ -243,7 +243,7 @@ async fn serve_req( async fn run_server(addr: SocketAddr) -> anyhow::Result<()> { let pool = db::ClientPool::new(); - db::run_migrations(&*pool.get().await) + db::run_migrations(&mut *pool.get().await) .await .context("database migrations")?;