Skip to content

Commit

Permalink
test(cubesql): Add tests for aggregation with WHERE false
Browse files Browse the repository at this point in the history
  • Loading branch information
mcheshkov committed Dec 6, 2024
1 parent 5b10a68 commit 3e606ea
Showing 1 changed file with 103 additions and 0 deletions.
103 changes: 103 additions & 0 deletions rust/cubesql/cubesql/src/compile/test/test_wrapper.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1383,3 +1383,106 @@ async fn wrapper_agg_dimension_over_limit() {
.sql
.contains("\"ungrouped\": true"));
}

/// Aggregation with falsy filter should NOT get pushed to CubeScan with limit=0
/// This test currently produces WrappedSelect with WHERE FALSE, which is OK for our purposes
#[tokio::test]
async fn select_agg_where_false() {
if !Rewriter::sql_push_down_enabled() {
return;
}
init_testing_logger();

let query_plan = convert_select_to_query_plan(
"SELECT SUM(sumPrice) FROM KibanaSampleDataEcommerce WHERE 1 = 0".to_string(),
DatabaseProtocol::PostgreSQL,
)
.await;

let physical_plan = query_plan.as_physical_plan().await.unwrap();
println!(
"Physical plan: {}",
displayable(physical_plan.as_ref()).indent()
);

let logical_plan = query_plan.as_logical_plan();
assert_eq!(
logical_plan.find_cube_scan().request,
V1LoadRequestQuery {
measures: Some(vec![]),
segments: Some(vec![]),
dimensions: Some(vec![]),
order: Some(vec![]),
limit: None,
ungrouped: Some(true),
..Default::default()
}
);

let sql = logical_plan
.find_cube_scan_wrapper()
.wrapped_sql
.unwrap()
.sql;

// Final query uses grouped query to Cube.js with WHERE FALSE, but without LIMIT 0
assert!(!sql.contains("\"ungrouped\":"));
assert!(sql.contains(r#"\"expr\":\"FALSE\""#));
assert!(sql.contains(r#""limit": 50000"#));
}

/// Aggregation(dimension) with falsy filter should NOT get pushed to CubeScan with limit=0
/// This test currently produces WrappedSelect with WHERE FALSE, which is OK for our purposes
#[tokio::test]
async fn wrapper_dimension_agg_where_false() {
if !Rewriter::sql_push_down_enabled() {
return;
}
init_testing_logger();

let query_plan = convert_select_to_query_plan(
// language=PostgreSQL
r#"
SELECT
MAX(customer_gender)
FROM
KibanaSampleDataEcommerce
WHERE 1 = 0
"#
.to_string(),
DatabaseProtocol::PostgreSQL,
)
.await;

let physical_plan = query_plan.as_physical_plan().await.unwrap();
println!(
"Physical plan: {}",
displayable(physical_plan.as_ref()).indent()
);

let logical_plan = query_plan.as_logical_plan();
assert_eq!(
logical_plan.find_cube_scan().request,
V1LoadRequestQuery {
measures: Some(vec![]),
dimensions: Some(vec![]),
segments: Some(vec![]),
order: Some(vec![]),
limit: None,
ungrouped: Some(true),
..Default::default()
}
);

let sql = logical_plan
.find_cube_scan_wrapper()
.wrapped_sql
.unwrap()
.sql;

// Final query uses grouped query to Cube.js with WHERE FALSE, but without LIMIT 0
assert!(!sql.contains("\"ungrouped\":"));
assert!(sql.contains(r#"\"expr\":\"FALSE\""#));
assert!(!sql.contains(r#""limit""#));
assert!(sql.contains("LIMIT 50000"));
}

0 comments on commit 3e606ea

Please sign in to comment.