mirror of
https://github.com/isar/rusqlite.git
synced 2024-11-25 02:21:37 +08:00
Show pathological cases
This commit is contained in:
parent
7f8c42116e
commit
7dfbc4b8d1
20
src/row.rs
20
src/row.rs
@ -585,4 +585,24 @@ mod tests {
|
|||||||
// We don't test one bigger because it's unimplemented
|
// We don't test one bigger because it's unimplemented
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
#[cfg(feature = "bundled")]
|
||||||
|
fn pathological_case() -> Result<()> {
|
||||||
|
let conn = Connection::open_in_memory()?;
|
||||||
|
conn.execute_batch(
|
||||||
|
"CREATE TABLE foo(x);
|
||||||
|
CREATE TRIGGER oops BEFORE INSERT ON foo BEGIN SELECT RAISE(FAIL, 'Boom'); END;",
|
||||||
|
)?;
|
||||||
|
let mut stmt = conn.prepare("INSERT INTO foo VALUES (0) RETURNING rowid;")?;
|
||||||
|
{
|
||||||
|
let n = stmt.query_map([], |_| Ok(()))?.count();
|
||||||
|
assert_eq!(1, n); // should be 0
|
||||||
|
}
|
||||||
|
{
|
||||||
|
let last = stmt.query_map([], |_| Ok(()))?.last();
|
||||||
|
assert!(last.is_some()); // should be none
|
||||||
|
}
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user