/* * ForgeFlux StarChart - A federated software forge spider * Copyright (C) 2022 Aravinth Manivannan * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see . */ use std::env; pub use std::sync::Arc; use crate::ctx::Ctx; pub use crate::db::BoxDB; pub use crate::federate::{get_federate, ArcFederate}; use crate::settings::{DBType, Settings}; //use actix_web::cookie::Cookie; use crate::errors::*; use crate::*; use actix_web::test; use actix_web::{ body::{BoxBody, EitherBody}, dev::ServiceResponse, error::ResponseError, http::StatusCode, }; use serde::Serialize; //pub mod sqlx_postgres { // use super::*; // // pub async fn get_ctx() -> (BoxDB, Arc) { // let url = env::var("POSTGRES_DATABASE_URL").unwrap(); // let mut settings = Settings::new().unwrap(); // settings.database.url = url.clone(); // settings.database.database_type = DBType::Postgres; // let db = pg::get_data(Some(settings.clone())).await; // (db, Ctx::new(Some(settings))) // } pub mod sqlx_sqlite { use super::*; use crate::db::sqlite; use mktemp::Temp; pub async fn get_ctx() -> (BoxDB, ArcCtx, ArcFederate, Temp) { let url = env::var("SQLITE_DATABASE_URL").unwrap(); env::set_var("DATABASE_URL", &url); println!("found db url: {url}"); let mut settings = Settings::new().unwrap(); settings.database.url = url.clone(); settings.database.database_type = DBType::Sqlite; let db = sqlite::get_data(Some(settings.clone())).await; let tmp_dir = Temp::new_dir().unwrap(); settings.repository.root = tmp_dir.to_str().unwrap().to_string(); let federate = get_federate(Some(settings.clone())).await; (db, Ctx::new(settings).await, federate, tmp_dir) } } #[macro_export] macro_rules! get_cookie { ($resp:expr) => { $resp.response().cookies().next().unwrap().to_owned() }; } #[allow(dead_code, clippy::upper_case_acronyms)] pub struct FORM; #[macro_export] macro_rules! post_request { ($uri:expr) => { test::TestRequest::post().uri($uri) }; ($serializable:expr, $uri:expr) => { test::TestRequest::post() .uri($uri) .insert_header((actix_web::http::header::CONTENT_TYPE, "application/json")) .set_payload(serde_json::to_string($serializable).unwrap()) }; ($serializable:expr, $uri:expr, FORM) => { test::TestRequest::post().uri($uri).set_form($serializable) }; } #[macro_export] macro_rules! get_request { ($app:expr,$route:expr ) => { test::call_service(&$app, test::TestRequest::get().uri($route).to_request()).await }; ($app:expr, $route:expr, $cookies:expr) => { test::call_service( &$app, test::TestRequest::get() .uri($route) .cookie($cookies) .to_request(), ) .await }; } #[macro_export] macro_rules! delete_request { ($app:expr,$route:expr ) => { test::call_service(&$app, test::TestRequest::delete().uri($route).to_request()).await }; ($app:expr, $route:expr, $cookies:expr) => { test::call_service( &$app, test::TestRequest::delete() .uri($route) .cookie($cookies) .to_request(), ) .await }; } #[macro_export] macro_rules! get_app { ("APP", $settings:expr) => { actix_web::App::new() .wrap(actix_web::middleware::NormalizePath::new( actix_web::middleware::TrailingSlash::Trim, )) .configure(crate::routes::services) }; ($settings:ident) => { test::init_service(get_app!("APP", $settings)) }; ($ctx:expr, $db:expr, $federate:expr) => { test::init_service( get_app!("APP", &$ctx.settings) .app_data(crate::WebDB::new($db.clone())) .app_data(crate::WebCtx::new($ctx.clone())) .app_data(crate::WebFederate::new($federate.clone())), ) }; } //impl Data { // /// register and signin utility // pub async fn register_and_signin( // &self, // db: &BoxDB, // name: &str, // email: &str, // password: &str, // ) -> (Login, ServiceResponse>) { // self.register_test(db, name, email, password).await; // self.signin_test(db, name, password).await // } // // pub fn to_arc(&self) -> Arc { // Arc::new(self.clone()) // } // // /// register utility // pub async fn register_test(&self, db: &BoxDB, name: &str, email: &str, password: &str) { // let app = get_app!(self.to_arc(), db.clone()).await; // // // 1. Register // let msg = Register { // username: name.into(), // password: password.into(), // confirm_password: password.into(), // email: Some(email.into()), // }; // let resp = // test::call_service(&app, post_request!(&msg, ROUTES.auth.register).to_request()).await; // // let resp_err: ErrorToResponse = test::read_body_json(resp).await; // // panic!("{}", resp_err.error); // assert_eq!(resp.status(), StatusCode::OK); // } // // /// signin util // pub async fn signin_test( // &self, // db: &BoxDB, // name: &str, // password: &str, // ) -> (Login, ServiceResponse>) { // let app = get_app!(self.to_arc(), db.clone()).await; // // // 2. signin // let creds = Login { // login: name.into(), // password: password.into(), // }; // let signin_resp = // test::call_service(&app, post_request!(&creds, ROUTES.auth.login).to_request()).await; // assert_eq!(signin_resp.status(), StatusCode::OK); // (creds, signin_resp) // } // // /// pub duplicate test // pub async fn bad_post_req_test( // &self, // db: &BoxDB, // name: &str, // password: &str, // url: &str, // payload: &T, // err: ServiceError, // ) { // let (_, signin_resp) = self.signin_test(db, name, password).await; // let cookies = get_cookie!(signin_resp); // let app = get_app!(self.to_arc(), db.clone()).await; // // let resp = test::call_service( // &app, // post_request!(&payload, url) // .cookie(cookies.clone()) // .to_request(), // ) // .await; // assert_eq!(resp.status(), err.status_code()); // let resp_err: ErrorToResponse = test::read_body_json(resp).await; // //println!("{}", txt.error); // assert_eq!(resp_err.error, format!("{}", err)); // } // // /// bad post req test without payload // pub async fn bad_post_req_test_witout_payload( // &self, // db: &BoxDB, // name: &str, // password: &str, // url: &str, // err: ServiceError, // ) { // let (_, signin_resp) = self.signin_test(db, name, password).await; // let app = get_app!(self.to_arc(), db.clone()).await; // let cookies = get_cookie!(signin_resp); // // let resp = test::call_service( // &app, // post_request!(url).cookie(cookies.clone()).to_request(), // ) // .await; // assert_eq!(resp.status(), err.status_code()); // let resp_err: ErrorToResponse = test::read_body_json(resp).await; // //println!("{}", resp_err.error); // assert_eq!(resp_err.error, format!("{}", err)); // } //}