diff --git a/.drone.yml b/.drone.yml index c9d0a100db..c6977ed9cf 100644 --- a/.drone.yml +++ b/.drone.yml @@ -34,9 +34,6 @@ steps: commands: - sudo apt-get update - sudo apt-get -y install --no-install-recommends espeak postgresql-client - - cargo install diesel_cli --no-default-features --features postgres --target-dir target/ - - ls -la target/ - - ./target/diesel migration run - cargo test --workspace --no-fail-fast - name: cargo build diff --git a/Cargo.lock b/Cargo.lock index cf741d6894..ef39f5fd53 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -935,6 +935,16 @@ dependencies = [ "lazy_static", ] +[[package]] +name = "ctor" +version = "0.1.16" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7fbaabec2c953050352311293be5c6aba8e141ba19d6811862b232d6fd020484" +dependencies = [ + "quote", + "syn", +] + [[package]] name = "darling" version = "0.10.2" @@ -1838,6 +1848,7 @@ dependencies = [ "awc", "cargo-husky", "chrono", + "ctor", "diesel", "diesel_migrations", "env_logger", diff --git a/Cargo.toml b/Cargo.toml index 99d755cc0b..ad5a6cd52f 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -49,6 +49,7 @@ reqwest = { version = "0.10", features = ["json"] } activitystreams = "0.7.0-alpha.4" actix-rt = { version = "1.1", default-features = false } serde_json = { version = "1.0", features = ["preserve_order"]} +ctor = "0.1.16" [dev-dependencies.cargo-husky] version = "1" diff --git a/lemmy_db/src/lib.rs b/lemmy_db/src/lib.rs index bad646d14b..b90c9416ff 100644 --- a/lemmy_db/src/lib.rs +++ b/lemmy_db/src/lib.rs @@ -214,7 +214,7 @@ lazy_static! { } #[cfg(test)] -mod tests { +pub mod tests { use super::fuzzy_search; use crate::{get_database_url_from_env, is_email_regex}; use diesel::{Connection, PgConnection}; diff --git a/src/main.rs b/src/main.rs index c55c3655d5..31c5f97090 100644 --- a/src/main.rs +++ b/src/main.rs @@ -92,3 +92,12 @@ async fn main() -> Result<(), LemmyError> { Ok(()) } + +#[cfg(test)] +#[ctor::ctor] +fn init() { + use lemmy_db::tests::establish_unpooled_connection; + let conn = establish_unpooled_connection(); + embedded_migrations::run(&conn).unwrap(); + run_advanced_migrations(&conn).unwrap(); +} \ No newline at end of file