use cdk_sql_common::mint::SQLMintAuthDatabase;
use cdk_sql_common::SQLMintDatabase;
use crate::common::SqliteConnectionManager;
pub mod memory;
pub type MintSqliteDatabase = SQLMintDatabase<SqliteConnectionManager>;
pub type MintSqliteAuthDatabase = SQLMintAuthDatabase<SqliteConnectionManager>;
#[cfg(test)]
mod test {
use std::fs::remove_file;
use cdk_common::mint_db_test;
use cdk_sql_common::pool::Pool;
use cdk_sql_common::stmt::query;
use super::*;
use crate::common::Config;
async fn provide_db(_test_name: String) -> MintSqliteDatabase {
memory::empty().await.unwrap()
}
mint_db_test!(provide_db);
#[tokio::test]
async fn bug_opening_relative_path() {
let config: Config = "test.db".into();
let pool = Pool::<SqliteConnectionManager>::new(config);
let db = pool.get();
assert!(db.is_ok());
let _ = remove_file("test.db");
}
#[tokio::test]
async fn open_legacy_and_migrate() {
let file = format!(
"{}/db.sqlite",
std::env::temp_dir().to_str().unwrap_or_default()
);
{
let _ = remove_file(&file);
#[cfg(not(feature = "sqlcipher"))]
let config: Config = file.as_str().into();
#[cfg(feature = "sqlcipher")]
let config: Config = (file.as_str(), "test").into();
let pool = Pool::<SqliteConnectionManager>::new(config);
let conn = pool.get().expect("valid connection");
query(include_str!("../../tests/legacy-sqlx.sql"))
.expect("query")
.execute(&*conn)
.await
.expect("create former db failed");
}
#[cfg(not(feature = "sqlcipher"))]
let conn = MintSqliteDatabase::new(file.as_str()).await;
#[cfg(feature = "sqlcipher")]
let conn = MintSqliteDatabase::new((file.as_str(), "test")).await;
assert!(conn.is_ok(), "Failed with {:?}", conn.unwrap_err());
let _ = remove_file(&file);
}
}