Adding code to use test database when in debug mode (#10)
Some checks failed
Release Tagging / release (push) Successful in 38s
Rust Build / Test Suite (push) Has been cancelled
Rust Build / Rustfmt (push) Has been cancelled
Rust Build / Clippy (push) Has been cancelled
Rust Build / Check (push) Has been cancelled
Rust Build / build (push) Has been cancelled
Some checks failed
Release Tagging / release (push) Successful in 38s
Rust Build / Test Suite (push) Has been cancelled
Rust Build / Rustfmt (push) Has been cancelled
Rust Build / Clippy (push) Has been cancelled
Rust Build / Check (push) Has been cancelled
Rust Build / build (push) Has been cancelled
Reviewed-on: #10 Co-authored-by: KD <kundeng94@gmail.com> Co-committed-by: KD <kundeng94@gmail.com>
This commit is contained in:
22
src/lib.rs
22
src/lib.rs
@@ -8,6 +8,13 @@ mod keys {
|
||||
pub mod error {
|
||||
pub const ERROR: &str = "DATABASE_URL must be set in .env";
|
||||
}
|
||||
|
||||
pub mod test {
|
||||
pub const DBURL: &str = "TEST_DATABASE_URL";
|
||||
pub mod error {
|
||||
pub const ERROR: &str = "TEST_DATABASE_URL must be set in .env";
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
mod connection_settings {
|
||||
@@ -22,12 +29,23 @@ pub mod db_pool {
|
||||
use crate::{connection_settings, keys};
|
||||
|
||||
pub async fn create_pool() -> Result<sqlx::PgPool, sqlx::Error> {
|
||||
dotenv::dotenv().ok();
|
||||
let database_url = env::var(keys::DBURL).expect(keys::error::ERROR);
|
||||
let database_url = get_db_url().await;
|
||||
println!("Database url: {:?}", database_url);
|
||||
|
||||
PgPoolOptions::new()
|
||||
.max_connections(connection_settings::MAXCONN)
|
||||
.connect(&database_url)
|
||||
.await
|
||||
}
|
||||
|
||||
async fn get_db_url() -> String {
|
||||
#[cfg(debug_assertions)] // Example: Only load .env in debug builds
|
||||
dotenvy::dotenv().ok();
|
||||
|
||||
if cfg!(debug_assertions) {
|
||||
env::var(keys::test::DBURL).expect(keys::test::error::ERROR)
|
||||
} else {
|
||||
env::var(keys::DBURL).expect(keys::error::ERROR)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user