From e01585bf1303b88a160242f775726d6681495011 Mon Sep 17 00:00:00 2001 From: Andy Hamon Date: Wed, 27 Nov 2024 09:43:34 -0500 Subject: [PATCH] Update appender tests to reflect computed columns support Prior to https://github.com/duckdb/duckdb/pull/14346, the C API did not support appending to tables with computed columns. This would cause panics until https://github.com/duckdb/duckdb-rs/pull/296, where a test was introduced asserting that an append to a table with computed columns returns an error value. Now that appending to is supported, update the test to reflect that. --- crates/duckdb/src/appender/mod.rs | 17 +++++++++-------- 1 file changed, 9 insertions(+), 8 deletions(-) diff --git a/crates/duckdb/src/appender/mod.rs b/crates/duckdb/src/appender/mod.rs index 96d176c4..de57f343 100644 --- a/crates/duckdb/src/appender/mod.rs +++ b/crates/duckdb/src/appender/mod.rs @@ -287,22 +287,23 @@ mod test { } #[test] - fn test_appender_error() -> Result<(), crate::Error> { + fn test_appender_computed_columns() -> Result<(), crate::Error> { let conn = Connection::open_in_memory()?; conn.execute( r"CREATE TABLE foo ( foobar TEXT, - foobar_split TEXT[] AS (split(trim(foobar), ',')) + foobar_twice TEXT AS (foobar || foobar) );", [], )?; let mut appender = conn.appender("foo")?; - match appender.append_row(["foo"]) { - Err(crate::Error::DuckDBFailure(.., Some(msg))) => { - assert_eq!(msg, "Call to EndRow before all columns have been appended to!") - } - _ => panic!("expected error"), - } + appender.append_row(["foo"])?; + appender.flush()?; + let val = conn.query_row("SELECT foobar, foobar_twice FROM foo", [], |row| { + <(String, String)>::try_from(row) + })?; + assert_eq!(val, ("foo".to_string(), "foofoo".to_string())); + Ok(()) } }