use ::oracle::Connection; use njord::condition::Condition; use njord::keys::AutoIncrementPrimaryKey; use njord::oracle; use njord::table::Table; use njord::util::JoinType; use njord::{column::Column, condition::Value}; use std::sync::Arc; use crate::{Category, CategoryWithJoin, Product}; fn insert_mock_data(conn: &mut Connection, table_rows: Vec) { let result = oracle::insert(conn, table_rows); assert!(result.is_ok()); } fn delete_mock_data( conn: &mut Connection, names: Vec, column: String, ) { // Transform Vec into Vec let value_list: Vec = names .into_iter() .map(Value::Literal) // Wrap each username as a Value::Literal .collect(); let result = oracle::delete() .from(T::default()) .where_clause(Condition::In(column, value_list)) .build(conn); assert!(result.is_ok()); } #[test] fn select_inner_join() { let connection_string = "//localhost:1521/FREEPDB1"; let mut conn = oracle::open("njord_user", "njord_password", connection_string); // Assume we have pre-inserted some data into the users and products tables let columns = vec![ Column::Text("categories.name".to_string()), Column::Text("products.name".to_string()), Column::Text("products.price".to_string()), ]; // Assuming a hypothetical join condition: users.id = products.user_id let join_condition = Condition::Eq( "categories.id".to_string(), Value::Literal("products.category_id".to_string()), ); match conn { Ok(ref mut c) => { insert_mock_data( c, vec![Category { id: AutoIncrementPrimaryKey::new(Some(1)), name: "select_inner_join_test".to_string(), }], ); insert_mock_data( c, vec![Product { id: AutoIncrementPrimaryKey::new(Some(1)), name: "select_inner_join_test".to_string(), description: "select_inner_join_test".to_string(), price: 10.0, stock_quantity: 10, discount: 0.0, category_id: 1, }], ); let result = oracle::select(columns) .from(CategoryWithJoin::default()) .join( JoinType::Inner, Arc::new(Product::default()), join_condition, ) .build(c); match result { Ok(r) => { // Check the number of results and assert against expected values assert!(!r.is_empty(), "Expected results, but got none."); // Further assertions on expected data can be made here based on inserted data } Err(e) => panic!("Failed to SELECT with JOIN: {:?}", e), }; delete_mock_data::( c, vec!["select_inner_join_test".to_string()], "name".to_string(), ); delete_mock_data::( c, vec!["select_inner_join_test".to_string()], "name".to_string(), ); } Err(e) => panic!("Failed to SELECT: {:?}", e), } } #[test] fn select_left_join() { let connection_string = "//localhost:1521/FREEPDB1"; let mut conn = oracle::open("njord_user", "njord_password", connection_string); // Assume we have pre-inserted some data into the users and products tables let columns = vec![ Column::Text("categories.name".to_string()), Column::Text("products.name".to_string()), Column::Text("products.price".to_string()), ]; // Assuming a hypothetical join condition: users.id = products.user_id let join_condition = Condition::Eq( "categories.id".to_string(), Value::Literal("products.category_id".to_string()), ); match conn { Ok(ref mut c) => { insert_mock_data( c, vec![Category { id: AutoIncrementPrimaryKey::new(Some(1)), name: "select_inner_join_test".to_string(), }], ); insert_mock_data( c, vec![Product { id: AutoIncrementPrimaryKey::new(Some(1)), name: "select_inner_join_test".to_string(), description: "select_inner_join_test".to_string(), price: 10.0, stock_quantity: 10, discount: 0.0, category_id: 1, }], ); let result = oracle::select(columns) .from(CategoryWithJoin::default()) .join(JoinType::Left, Arc::new(Product::default()), join_condition) .build(c); match result { Ok(r) => { // Check the number of results and assert against expected values assert!(!r.is_empty(), "Expected results, but got none."); // Further assertions on expected data can be made here based on inserted data } Err(e) => panic!("Failed to SELECT with JOIN: {:?}", e), }; delete_mock_data::( c, vec!["select_inner_join_test".to_string()], "name".to_string(), ); delete_mock_data::( c, vec!["select_inner_join_test".to_string()], "name".to_string(), ); } Err(e) => panic!("Failed to SELECT: {:?}", e), } }