From cebb6642daf8b528ed8c95be9fc47709abe1c50a Mon Sep 17 00:00:00 2001 From: Joel Natividad <1980690+jqnatividad@users.noreply.github.com> Date: Tue, 24 Dec 2024 06:43:34 -0500 Subject: [PATCH] fix: util::get_stats_records no longer infers boolean in StatsMode::PolarsSchema this ultimately was the root cause of the problem reported in #2369 --- src/util.rs | 4 ++-- tests/test_joinp.rs | 8 +++++--- 2 files changed, 7 insertions(+), 5 deletions(-) diff --git a/src/util.rs b/src/util.rs index bc11b6808..eeca99ca9 100644 --- a/src/util.rs +++ b/src/util.rs @@ -2102,8 +2102,8 @@ pub fn get_stats_records( #[cfg(feature = "polars")] StatsMode::PolarsSchema => { // StatsMode::PolarsSchema - // we need data types and ranges - format!("stats\t{input}\t--infer-boolean\t--stats-jsonl\t--output\t{tempfile_path}") + // we need data types, ranges & cardinality + format!("stats\t{input}\t--cardinality\t--stats-jsonl\t--output\t{tempfile_path}") }, StatsMode::None => unreachable!(), // we returned early on None earlier }; diff --git a/tests/test_joinp.rs b/tests/test_joinp.rs index 99fbc779f..e00b774fe 100644 --- a/tests/test_joinp.rs +++ b/tests/test_joinp.rs @@ -195,6 +195,8 @@ joinp_test!(joinp_inner, |wrk: Workdir, mut cmd: process::Command| { joinp_test_cache_schema!( joinp_inner_cache_schema, |wrk: Workdir, mut cmd: process::Command| { + wrk.assert_success(&mut cmd); + let got: Vec> = wrk.read_stdout(&mut cmd); let expected = make_rows( false, @@ -1701,9 +1703,9 @@ fn test_joinp_cache_schema() { .arg("--cache-schema") .arg("1"); - // error is expected as has_text is interpreted as bool, rather than a number of just a string - // recreates error reported in https://github.com/dathere/qsv/issues/2369 - wrk.assert_err(&mut cmd); + // success is expected as has_text is no longer interpreted as bool + // confirms bug reported in https://github.com/dathere/qsv/issues/2369 no longer exists + wrk.assert_success(&mut cmd); // Verify schema files were created assert!(wrk.path("left.pschema.json").exists());