use rhttpd::{config::ServerConfig, server::ProxyServer}; use std::collections::HashMap; #[tokio::test] async fn test_static_file_serving() { // Create test configuration let mut sites = HashMap::new(); sites.insert( "test.com".to_string(), rhttpd::config::SiteConfig { hostname: "test.com".to_string(), routes: vec![rhttpd::config::RouteRule::Static { path_pattern: "/*".to_string(), root: std::path::PathBuf::from("./public"), index: Some(vec!["index.html".to_string()]), directory_listing: Some(false), }], tls: None, }, ); let config = ServerConfig { port: 8081, sites, js_config: None, connection_pool: None, health_check: None, }; let server = ProxyServer::new(config); // Test that server can be created assert_eq!(server.config.port, 8081); } #[tokio::test] async fn test_config_loading() { // Test loading a valid TOML config let config_result = ServerConfig::from_file("config.toml"); assert!(config_result.is_ok()); let config = config_result.unwrap(); assert_eq!(config.port, 8080); assert!(config.sites.contains_key("example.com")); } #[tokio::test] async fn test_connection_pool() { use rhttpd::proxy::connection_pool::ConnectionPool; let pool = ConnectionPool::new(10, std::time::Duration::from_secs(90)); let result = pool.get_connection("test.example.com").await; assert!(result.is_ok()); let stats = pool.get_pool_stats().await; assert_eq!(stats.total_connections, 1); } #[tokio::test] async fn test_load_balancer() { use rhttpd::proxy::load_balancer::{LoadBalancer, LoadBalancerStrategy}; let upstreams = vec![ "http://backend1:3000".to_string(), "http://backend2:3000".to_string(), ]; let lb = LoadBalancer::new(LoadBalancerStrategy::RoundRobin, upstreams); let upstream = lb.select_upstream().await; assert!(upstream.is_some()); let stats = lb.get_stats().await; assert_eq!(stats.total_upstreams, 2); }