Actix-Demo/tests/integration/common/mod.rs

122 lines
3.4 KiB
Rust
Raw Normal View History

2021-05-05 14:30:11 +00:00
extern crate actix_demo;
2021-05-10 06:47:06 +00:00
use actix_demo::{AppConfig, AppData, EnvConfig};
2021-05-05 14:30:11 +00:00
use actix_web::test;
use actix_web::App;
use diesel::r2d2::{self, ConnectionManager};
use std::io;
use std::io::ErrorKind;
2021-05-10 06:47:06 +00:00
use tracing::subscriber::set_global_default;
use tracing_actix_web::TracingLogger;
use tracing_log::LogTracer;
use tracing_subscriber::fmt::{format::FmtSpan, Subscriber as FmtSubscriber};
use tracing_subscriber::{layer::SubscriberExt, EnvFilter};
2021-05-05 14:30:11 +00:00
use actix_demo::configure_app;
use actix_http::Request;
use actix_web::{dev as ax_dev, Error as AxError};
2021-05-10 06:47:06 +00:00
pub async fn test_app() -> io::Result<
impl ax_dev::Service<
Request = Request,
Response = ax_dev::ServiceResponse<impl ax_dev::MessageBody>,
Error = AxError,
>,
2021-05-05 14:30:11 +00:00
> {
2021-05-10 06:47:06 +00:00
let _ = dotenv::dotenv().map_err(|err| {
io::Error::new(
ErrorKind::Other,
format!("Failed to set up env: {:?}", err),
)
})?;
let _ = envy::prefixed("ACTIX_DEMO_")
.from_env::<EnvConfig>()
2021-05-05 14:30:11 +00:00
.map_err(|err| {
io::Error::new(
ErrorKind::Other,
2021-05-10 06:47:06 +00:00
format!("Failed to parse config: {:?}", err),
2021-05-05 14:30:11 +00:00
)
2021-05-10 06:47:06 +00:00
})?;
2021-05-05 14:30:11 +00:00
2021-05-10 06:47:06 +00:00
let env_filter =
EnvFilter::try_from_env("ACTIX_DEMO_RUST_LOG").map_err(|err| {
2021-05-05 14:30:11 +00:00
io::Error::new(
ErrorKind::Other,
2021-05-10 06:47:06 +00:00
format!("Failed to set up env logger: {:?}", err),
2021-05-05 14:30:11 +00:00
)
2021-05-10 06:47:06 +00:00
})?;
let _ = LogTracer::init().map_err(|err| {
io::Error::new(
ErrorKind::Other,
format!("Failed to set up log tracer: {:?}", err),
)
});
let subscriber = FmtSubscriber::builder()
.pretty()
.with_test_writer()
.with_span_events(FmtSpan::NEW)
.with_span_events(FmtSpan::CLOSE)
.finish()
.with(env_filter);
let _ = set_global_default(subscriber).map_err(|err| {
io::Error::new(
ErrorKind::Other,
format!("Failed to set subscriber: {:?}", err),
)
});
let connspec = ":memory:";
2021-05-11 06:12:37 +00:00
let manager = ConnectionManager::<
diesel_tracing::sqlite::InstrumentedSqliteConnection,
>::new(connspec);
2021-05-10 06:47:06 +00:00
let pool = r2d2::Pool::builder().build(manager).map_err(|err| {
io::Error::new(
ErrorKind::Other,
format!("Failed to create pool: {:?}", err),
)
})?;
2021-05-05 14:30:11 +00:00
let _ = {
2021-05-10 06:47:06 +00:00
let conn = &pool.get().map_err(|err| {
io::Error::new(
ErrorKind::Other,
format!("Failed to get connection: {:?}", err),
)
})?;
2021-05-05 14:30:11 +00:00
let migrations_dir = diesel_migrations::find_migrations_directory()
.map_err(|err| {
io::Error::new(
ErrorKind::Other,
format!("Error finding migrations dir: {:?}", err),
)
2021-05-10 06:47:06 +00:00
})?;
2021-05-05 14:30:11 +00:00
let _ = diesel_migrations::run_pending_migrations_in_directory(
conn,
&migrations_dir,
&mut io::sink(),
)
.map_err(|err| {
io::Error::new(
ErrorKind::Other,
format!("Error running migrations: {:?}", err),
)
2021-05-10 06:47:06 +00:00
})?;
2021-05-05 14:30:11 +00:00
};
2021-05-10 06:47:06 +00:00
Ok(test::init_service(
2021-05-05 14:30:11 +00:00
App::new()
.configure(configure_app(AppData {
config: AppConfig { hash_cost: 8 },
pool,
}))
2021-05-10 06:47:06 +00:00
.wrap(TracingLogger),
2021-05-05 14:30:11 +00:00
)
2021-05-10 06:47:06 +00:00
.await)
2021-05-05 14:30:11 +00:00
}