From c9079c4325b0910d4f3218381bef3ca218258595 Mon Sep 17 00:00:00 2001 From: John Vandenberg Date: Sun, 21 Apr 2024 10:28:40 +0800 Subject: [PATCH] Add test to unmigrate test models (#252) --- butane/tests/r2d2.rs | 8 ++------ butane/tests/unmigrate.rs | 20 ++++++++++++++++++++ butane_test_helper/src/lib.rs | 23 ++++++++++++++++------- 3 files changed, 38 insertions(+), 13 deletions(-) create mode 100644 butane/tests/unmigrate.rs diff --git a/butane/tests/r2d2.rs b/butane/tests/r2d2.rs index c4183e03..42f7226c 100644 --- a/butane/tests/r2d2.rs +++ b/butane/tests/r2d2.rs @@ -19,11 +19,7 @@ fn r2d2_sqlite() { let mut conn1 = pool.get().unwrap(); assert_eq!(pool.state().connections, 3); assert_eq!(pool.state().idle_connections, 2); - setup_db( - Box::new(butane::db::sqlite::SQLiteBackend::new()), - &mut conn1, - true, - ); + setup_db(&mut conn1); let _conn2 = pool.get().unwrap(); assert_eq!(pool.state().idle_connections, 1); @@ -42,7 +38,7 @@ fn r2d2_pq() { let mut conn1 = pool.get().unwrap(); assert_eq!(pool.state().connections, 3); assert_eq!(pool.state().idle_connections, 2); - setup_db(Box::new(butane::db::pg::PgBackend::new()), &mut conn1, true); + setup_db(&mut conn1); let _conn2 = pool.get().unwrap(); assert_eq!(pool.state().idle_connections, 1); diff --git a/butane/tests/unmigrate.rs b/butane/tests/unmigrate.rs new file mode 100644 index 00000000..683b7699 --- /dev/null +++ b/butane/tests/unmigrate.rs @@ -0,0 +1,20 @@ +//! Test the "current" migration created by the butane_test_helper due to +//! all of the other tests in the butane/tests directory. +#![cfg(test)] +use butane::db::Connection; +use butane::migrations::{Migration, Migrations}; +use butane_test_helper::*; + +fn unmigrate(mut connection: Connection) { + let mem_migrations = create_current_migrations(&connection); + + let migrations = mem_migrations.unapplied_migrations(&connection).unwrap(); + assert_eq!(migrations.len(), 0); + + let migration = mem_migrations.latest().unwrap(); + migration.downgrade(&mut connection).unwrap(); + + let migrations = mem_migrations.unapplied_migrations(&connection).unwrap(); + assert_eq!(migrations.len(), 1); +} +testall!(unmigrate); diff --git a/butane_test_helper/src/lib.rs b/butane_test_helper/src/lib.rs index 9bb1e8c8..bec19266 100644 --- a/butane_test_helper/src/lib.rs +++ b/butane_test_helper/src/lib.rs @@ -9,7 +9,9 @@ use std::process::{ChildStderr, Command, Stdio}; use std::sync::Mutex; use block_id::{Alphabet, BlockId}; -use butane_core::db::{connect, get_backend, pg, sqlite, Backend, Connection, ConnectionSpec}; +use butane_core::db::{ + connect, get_backend, pg, sqlite, Backend, BackendConnection, Connection, ConnectionSpec, +}; use butane_core::migrations::{self, MemMigrations, Migration, Migrations, MigrationsMut}; use once_cell::sync::Lazy; use uuid::Uuid; @@ -179,16 +181,15 @@ pub fn pg_connstr(data: &PgSetupData) -> String { data.connstr.clone() } -/// Populate the database schema. -pub fn setup_db(backend: Box, conn: &mut Connection, migrate: bool) { +/// Create a [`MemMigrations`]` for the "current" migration. +pub fn create_current_migrations(connection: &Connection) -> MemMigrations { + let backend = connection.backend(); + let mut root = std::env::current_dir().unwrap(); root.push(".butane/migrations"); let mut disk_migrations = migrations::from_root(&root); let disk_current = disk_migrations.current(); log::info!("Loading migrations from {:?}", disk_current); - if !migrate { - return; - } // Create an in-memory Migrations and write only to that. This // allows concurrent tests to avoid stomping on each other and is // also faster than real disk writes. @@ -208,6 +209,12 @@ pub fn setup_db(backend: Box, conn: &mut Connection, migrate: bool) .expect("expected to create migration without error"), "expected to create migration" ); + mem_migrations +} + +/// Populate the database schema. +pub fn setup_db(conn: &mut Connection) { + let mem_migrations = create_current_migrations(conn); log::info!("created current migration"); mem_migrations.migrate(conn).unwrap(); } @@ -240,7 +247,9 @@ macro_rules! maketest { let $dataname = butane_test_helper::[<$backend _setup>](); log::info!("connecting to {}..", &$connstr); let mut conn = backend.connect(&$connstr).expect("Could not connect backend"); - butane_test_helper::setup_db(backend, &mut conn, $migrate); + if $migrate { + butane_test_helper::setup_db(&mut conn); + } log::info!("running test on {}..", &$connstr); $fname(conn); butane_test_helper::[<$backend _teardown>]($dataname);