#[allow(unused_imports)]
use vantage_sql::postgres::AnyPostgresType;
use vantage_sql::postgres::PostgresDB;
#[allow(unused_imports)]
use vantage_sql::postgres::PostgresType;
use vantage_sql::postgres::operation::PostgresOperation;
use vantage_sql::postgres_expr;
use vantage_table::table::Table;
use vantage_types::entity;
use vantage_dataset::ReadableDataSet;
const PG_URL: &str = "postgres://vantage:vantage@localhost:5433/vantage";
async fn get_db() -> PostgresDB {
PostgresDB::connect(PG_URL).await.unwrap()
}
#[entity(PostgresType)]
#[derive(Debug, Clone, PartialEq, Default)]
struct Product {
name: String,
calories: i64,
price: i64,
bakery_id: String,
is_deleted: bool,
inventory_stock: i64,
}
impl Product {
fn postgres_table(db: PostgresDB) -> Table<PostgresDB, Product> {
Table::new("product", db)
.with_id_column("id")
.with_column_of::<String>("name")
.with_column_of::<i64>("calories")
.with_column_of::<i64>("price")
.with_column_of::<String>("bakery_id")
.with_column_of::<bool>("is_deleted")
.with_column_of::<i64>("inventory_stock")
}
}
#[tokio::test]
async fn test_custom_expression_condition() {
let db = get_db().await;
let mut table = Product::postgres_table(db);
table.add_condition(postgres_expr!("{} > {}", (table["price"]), 130i64));
let products = table.list().await.unwrap();
assert_eq!(products.len(), 4); }
#[tokio::test]
async fn test_multiple_conditions() {
let db = get_db().await;
let mut table = Product::postgres_table(db);
table.add_condition(postgres_expr!("{} > {}", (table["price"]), 130i64));
table.add_condition(postgres_expr!(
"{} > {}",
(table["price"]),
(table["calories"])
));
let products = table.list().await.unwrap();
assert_eq!(products.len(), 2);
}
#[tokio::test]
async fn test_operation_eq() {
let db = get_db().await;
let mut table = Product::postgres_table(db);
table.add_condition(table["is_deleted"].eq(false));
let products = table.list().await.unwrap();
assert_eq!(products.len(), 5); }