|
|
|
|
@@ -1702,7 +1702,6 @@ mod tests {
|
|
|
|
|
if path.exists() {
|
|
|
|
|
std::fs::remove_file(path).unwrap();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
let mut catalog_setup = Catalog::new(db_path);
|
|
|
|
|
catalog_setup.init().unwrap();
|
|
|
|
|
let items = vec![
|
|
|
|
|
@@ -1730,20 +1729,17 @@ mod tests {
|
|
|
|
|
];
|
|
|
|
|
catalog_setup.insert_many(items).unwrap();
|
|
|
|
|
catalog_setup.persist().unwrap();
|
|
|
|
|
|
|
|
|
|
// Edge Case 1: Value equal to filter value should not be included.
|
|
|
|
|
let mut catalog1 = Catalog::new(db_path);
|
|
|
|
|
let filter1 = Filter::new().with_signed_int("sell_trend", Comparison::Lesser, 10);
|
|
|
|
|
assert!(catalog1.load_by_filter(&filter1).is_ok());
|
|
|
|
|
assert_eq!(catalog1.items.len(), 1);
|
|
|
|
|
assert!(catalog1.items.contains_key("item-2"));
|
|
|
|
|
|
|
|
|
|
// Edge Case 2: No values lesser than filter value.
|
|
|
|
|
let mut catalog2 = Catalog::new(db_path);
|
|
|
|
|
let filter2 = Filter::new().with_signed_int("sell_trend", Comparison::Lesser, -5);
|
|
|
|
|
assert!(catalog2.load_by_filter(&filter2).is_ok());
|
|
|
|
|
assert!(catalog2.items.is_empty());
|
|
|
|
|
|
|
|
|
|
// Edge Case 3: All values lesser than filter value.
|
|
|
|
|
let mut catalog3 = Catalog::new(db_path);
|
|
|
|
|
let filter3 = Filter::new().with_signed_int("sell_trend", Comparison::Lesser, 25);
|
|
|
|
|
@@ -1752,10 +1748,8 @@ mod tests {
|
|
|
|
|
assert!(catalog3.items.contains_key("item-1"));
|
|
|
|
|
assert!(catalog3.items.contains_key("item-2"));
|
|
|
|
|
assert!(catalog3.items.contains_key("item-3"));
|
|
|
|
|
|
|
|
|
|
std::fs::remove_file(path).unwrap();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
|
fn load_by_filter_should_load_matching_greater_or_equal_sell_trend() {
|
|
|
|
|
let db_path = "target/test_dbs/lbf_matching_greater_or_equal_sell_trend.db";
|
|
|
|
|
@@ -1764,7 +1758,6 @@ mod tests {
|
|
|
|
|
if path.exists() {
|
|
|
|
|
std::fs::remove_file(path).unwrap();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
let mut catalog_setup = Catalog::new(db_path);
|
|
|
|
|
catalog_setup.init().unwrap();
|
|
|
|
|
let items = vec![
|
|
|
|
|
@@ -1792,19 +1785,15 @@ mod tests {
|
|
|
|
|
];
|
|
|
|
|
catalog_setup.insert_many(items).unwrap();
|
|
|
|
|
catalog_setup.persist().unwrap();
|
|
|
|
|
|
|
|
|
|
let mut catalog = Catalog::new(db_path);
|
|
|
|
|
let filter = Filter::new().with_signed_int("sell_trend", Comparison::GreaterOrEqual, 10);
|
|
|
|
|
assert!(catalog.load_by_filter(&filter).is_ok());
|
|
|
|
|
|
|
|
|
|
assert_eq!(catalog.items.len(), 2);
|
|
|
|
|
assert!(catalog.items.contains_key("item-1"));
|
|
|
|
|
assert!(!catalog.items.contains_key("item-2"));
|
|
|
|
|
assert!(catalog.items.contains_key("item-3"));
|
|
|
|
|
|
|
|
|
|
std::fs::remove_file(path).unwrap();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
|
fn load_by_filter_should_load_matching_greater_or_equal_sell_trend_edge_cases() {
|
|
|
|
|
let db_path = "target/test_dbs/lbf_greater_or_equal_sell_trend_edge_cases.db";
|
|
|
|
|
@@ -1813,7 +1802,6 @@ mod tests {
|
|
|
|
|
if path.exists() {
|
|
|
|
|
std::fs::remove_file(path).unwrap();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
let mut catalog_setup = Catalog::new(db_path);
|
|
|
|
|
catalog_setup.init().unwrap();
|
|
|
|
|
let items = vec![
|
|
|
|
|
@@ -1841,20 +1829,17 @@ mod tests {
|
|
|
|
|
];
|
|
|
|
|
catalog_setup.insert_many(items).unwrap();
|
|
|
|
|
catalog_setup.persist().unwrap();
|
|
|
|
|
|
|
|
|
|
// Edge Case 1: Value equal to filter value should be included.
|
|
|
|
|
let mut catalog1 = Catalog::new(db_path);
|
|
|
|
|
let filter1 = Filter::new().with_signed_int("sell_trend", Comparison::GreaterOrEqual, 20);
|
|
|
|
|
assert!(catalog1.load_by_filter(&filter1).is_ok());
|
|
|
|
|
assert_eq!(catalog1.items.len(), 1);
|
|
|
|
|
assert!(catalog1.items.contains_key("item-3"));
|
|
|
|
|
|
|
|
|
|
// Edge Case 2: No values greater than or equal to filter value.
|
|
|
|
|
let mut catalog2 = Catalog::new(db_path);
|
|
|
|
|
let filter2 = Filter::new().with_signed_int("sell_trend", Comparison::GreaterOrEqual, 21);
|
|
|
|
|
assert!(catalog2.load_by_filter(&filter2).is_ok());
|
|
|
|
|
assert!(catalog2.items.is_empty());
|
|
|
|
|
|
|
|
|
|
// Edge Case 3: All values greater than or equal to filter value.
|
|
|
|
|
let mut catalog3 = Catalog::new(db_path);
|
|
|
|
|
let filter3 = Filter::new().with_signed_int("sell_trend", Comparison::GreaterOrEqual, -5);
|
|
|
|
|
@@ -1863,10 +1848,8 @@ mod tests {
|
|
|
|
|
assert!(catalog3.items.contains_key("item-1"));
|
|
|
|
|
assert!(catalog3.items.contains_key("item-2"));
|
|
|
|
|
assert!(catalog3.items.contains_key("item-3"));
|
|
|
|
|
|
|
|
|
|
std::fs::remove_file(path).unwrap();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
|
fn load_by_filter_should_load_matching_lesser_or_equal_sell_trend() {
|
|
|
|
|
let db_path = "target/test_dbs/lbf_matching_lesser_or_equal_sell_trend.db";
|
|
|
|
|
@@ -1875,7 +1858,6 @@ mod tests {
|
|
|
|
|
if path.exists() {
|
|
|
|
|
std::fs::remove_file(path).unwrap();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
let mut catalog_setup = Catalog::new(db_path);
|
|
|
|
|
catalog_setup.init().unwrap();
|
|
|
|
|
let items = vec![
|
|
|
|
|
@@ -1903,19 +1885,15 @@ mod tests {
|
|
|
|
|
];
|
|
|
|
|
catalog_setup.insert_many(items).unwrap();
|
|
|
|
|
catalog_setup.persist().unwrap();
|
|
|
|
|
|
|
|
|
|
let mut catalog = Catalog::new(db_path);
|
|
|
|
|
let filter = Filter::new().with_signed_int("sell_trend", Comparison::LesserOrEqual, 10);
|
|
|
|
|
assert!(catalog.load_by_filter(&filter).is_ok());
|
|
|
|
|
|
|
|
|
|
assert_eq!(catalog.items.len(), 2);
|
|
|
|
|
assert!(catalog.items.contains_key("item-1"));
|
|
|
|
|
assert!(catalog.items.contains_key("item-2"));
|
|
|
|
|
assert!(!catalog.items.contains_key("item-3"));
|
|
|
|
|
|
|
|
|
|
std::fs::remove_file(path).unwrap();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
|
fn load_by_filter_should_load_matching_lesser_or_equal_sell_trend_edge_cases() {
|
|
|
|
|
let db_path = "target/test_dbs/lbf_lesser_or_equal_sell_trend_edge_cases.db";
|
|
|
|
|
@@ -1924,7 +1902,6 @@ mod tests {
|
|
|
|
|
if path.exists() {
|
|
|
|
|
std::fs::remove_file(path).unwrap();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
let mut catalog_setup = Catalog::new(db_path);
|
|
|
|
|
catalog_setup.init().unwrap();
|
|
|
|
|
let items = vec![
|
|
|
|
|
@@ -1952,20 +1929,17 @@ mod tests {
|
|
|
|
|
];
|
|
|
|
|
catalog_setup.insert_many(items).unwrap();
|
|
|
|
|
catalog_setup.persist().unwrap();
|
|
|
|
|
|
|
|
|
|
// Edge Case 1: Value equal to filter value should be included.
|
|
|
|
|
let mut catalog1 = Catalog::new(db_path);
|
|
|
|
|
let filter1 = Filter::new().with_signed_int("sell_trend", Comparison::LesserOrEqual, -5);
|
|
|
|
|
assert!(catalog1.load_by_filter(&filter1).is_ok());
|
|
|
|
|
assert_eq!(catalog1.items.len(), 1);
|
|
|
|
|
assert!(catalog1.items.contains_key("item-2"));
|
|
|
|
|
|
|
|
|
|
// Edge Case 2: No values lesser than or equal to filter value.
|
|
|
|
|
let mut catalog2 = Catalog::new(db_path);
|
|
|
|
|
let filter2 = Filter::new().with_signed_int("sell_trend", Comparison::LesserOrEqual, -6);
|
|
|
|
|
assert!(catalog2.load_by_filter(&filter2).is_ok());
|
|
|
|
|
assert!(catalog2.items.is_empty());
|
|
|
|
|
|
|
|
|
|
// Edge Case 3: All values lesser than or equal to filter value.
|
|
|
|
|
let mut catalog3 = Catalog::new(db_path);
|
|
|
|
|
let filter3 = Filter::new().with_signed_int("sell_trend", Comparison::LesserOrEqual, 20);
|
|
|
|
|
@@ -1974,7 +1948,6 @@ mod tests {
|
|
|
|
|
assert!(catalog3.items.contains_key("item-1"));
|
|
|
|
|
assert!(catalog3.items.contains_key("item-2"));
|
|
|
|
|
assert!(catalog3.items.contains_key("item-3"));
|
|
|
|
|
|
|
|
|
|
std::fs::remove_file(path).unwrap();
|
|
|
|
|
}
|
|
|
|
|
// ## Integration Tests
|
|
|
|
|
@@ -2223,4 +2196,83 @@ mod tests {
|
|
|
|
|
// Clean up
|
|
|
|
|
std::fs::remove_file(path).unwrap();
|
|
|
|
|
}
|
|
|
|
|
#[test]
|
|
|
|
|
fn load_by_filter_should_load_unsigned_int_comparisons() {
|
|
|
|
|
let db_path = "target/test_dbs/lbf_unsigned_int_comparisons.db";
|
|
|
|
|
let path = std::path::Path::new(db_path);
|
|
|
|
|
std::fs::create_dir_all(path.parent().unwrap()).unwrap();
|
|
|
|
|
if path.exists() {
|
|
|
|
|
std::fs::remove_file(path).unwrap();
|
|
|
|
|
}
|
|
|
|
|
let mut catalog_setup = Catalog::new(db_path);
|
|
|
|
|
catalog_setup.init().unwrap();
|
|
|
|
|
let items = vec![
|
|
|
|
|
Item {
|
|
|
|
|
id: "item-1".to_string(),
|
|
|
|
|
name: "Item One".to_string(),
|
|
|
|
|
price: 100,
|
|
|
|
|
sell_trend: 0,
|
|
|
|
|
in_stock: true,
|
|
|
|
|
},
|
|
|
|
|
Item {
|
|
|
|
|
id: "item-2".to_string(),
|
|
|
|
|
name: "Item Two".to_string(),
|
|
|
|
|
price: 200,
|
|
|
|
|
sell_trend: 0,
|
|
|
|
|
in_stock: false,
|
|
|
|
|
},
|
|
|
|
|
Item {
|
|
|
|
|
id: "item-3".to_string(),
|
|
|
|
|
name: "Item Three".to_string(),
|
|
|
|
|
price: 300,
|
|
|
|
|
sell_trend: 0,
|
|
|
|
|
in_stock: true,
|
|
|
|
|
},
|
|
|
|
|
];
|
|
|
|
|
catalog_setup.insert_many(items).unwrap();
|
|
|
|
|
catalog_setup.persist().unwrap();
|
|
|
|
|
// Equal
|
|
|
|
|
let mut catalog = Catalog::new(db_path);
|
|
|
|
|
let filter = Filter::new().with_unsigned_int("price", Comparison::Equal, 200);
|
|
|
|
|
assert!(catalog.load_by_filter(&filter).is_ok());
|
|
|
|
|
assert_eq!(catalog.items.len(), 1);
|
|
|
|
|
assert!(catalog.items.contains_key("item-2"));
|
|
|
|
|
// Greater
|
|
|
|
|
let mut catalog = Catalog::new(db_path);
|
|
|
|
|
let filter = Filter::new().with_unsigned_int("price", Comparison::Greater, 200);
|
|
|
|
|
assert!(catalog.load_by_filter(&filter).is_ok());
|
|
|
|
|
assert_eq!(catalog.items.len(), 1);
|
|
|
|
|
assert!(catalog.items.contains_key("item-3"));
|
|
|
|
|
// Lesser
|
|
|
|
|
let mut catalog = Catalog::new(db_path);
|
|
|
|
|
let filter = Filter::new().with_unsigned_int("price", Comparison::Lesser, 200);
|
|
|
|
|
assert!(catalog.load_by_filter(&filter).is_ok());
|
|
|
|
|
assert_eq!(catalog.items.len(), 1);
|
|
|
|
|
assert!(catalog.items.contains_key("item-1"));
|
|
|
|
|
// GreaterOrEqual
|
|
|
|
|
let mut catalog = Catalog::new(db_path);
|
|
|
|
|
let filter = Filter::new().with_unsigned_int("price", Comparison::GreaterOrEqual, 200);
|
|
|
|
|
assert!(catalog.load_by_filter(&filter).is_ok());
|
|
|
|
|
assert_eq!(catalog.items.len(), 2);
|
|
|
|
|
assert!(catalog.items.contains_key("item-2"));
|
|
|
|
|
assert!(catalog.items.contains_key("item-3"));
|
|
|
|
|
// LesserOrEqual
|
|
|
|
|
let mut catalog = Catalog::new(db_path);
|
|
|
|
|
let filter = Filter::new().with_unsigned_int("price", Comparison::LesserOrEqual, 200);
|
|
|
|
|
assert!(catalog.load_by_filter(&filter).is_ok());
|
|
|
|
|
assert_eq!(catalog.items.len(), 2);
|
|
|
|
|
assert!(catalog.items.contains_key("item-1"));
|
|
|
|
|
assert!(catalog.items.contains_key("item-2"));
|
|
|
|
|
// Edge case: No match
|
|
|
|
|
let mut catalog = Catalog::new(db_path);
|
|
|
|
|
let filter = Filter::new().with_unsigned_int("price", Comparison::Equal, 400);
|
|
|
|
|
assert!(catalog.load_by_filter(&filter).is_ok());
|
|
|
|
|
assert!(catalog.items.is_empty());
|
|
|
|
|
// Edge case: All match
|
|
|
|
|
let mut catalog = Catalog::new(db_path);
|
|
|
|
|
let filter = Filter::new().with_unsigned_int("price", Comparison::GreaterOrEqual, 100);
|
|
|
|
|
assert!(catalog.load_by_filter(&filter).is_ok());
|
|
|
|
|
assert_eq!(catalog.items.len(), 3);
|
|
|
|
|
std::fs::remove_file(path).unwrap();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|