salsa/tests/panic_safely.rs

66 lines
1.6 KiB
Rust
Raw Normal View History

2018-11-01 00:06:06 +00:00
use salsa::{Database, ParallelDatabase, Snapshot};
use std::panic::{self, AssertUnwindSafe};
salsa::query_group! {
trait PanicSafelyDatabase: salsa::Database {
fn one() -> usize {
type One;
storage input;
}
fn panic_safely() -> () {
type PanicSafely;
}
}
}
fn panic_safely(db: &impl PanicSafelyDatabase) -> () {
assert_eq!(db.one(), 1);
}
#[derive(Default)]
struct DatabaseStruct {
runtime: salsa::Runtime<DatabaseStruct>,
}
impl salsa::Database for DatabaseStruct {
fn salsa_runtime(&self) -> &salsa::Runtime<DatabaseStruct> {
&self.runtime
}
}
2018-10-31 19:59:00 +00:00
impl salsa::ParallelDatabase for DatabaseStruct {
2018-11-01 00:06:06 +00:00
fn snapshot(&self) -> Snapshot<Self> {
Snapshot::new(DatabaseStruct {
2018-11-01 00:05:31 +00:00
runtime: self.runtime.snapshot(self),
2018-10-31 19:59:00 +00:00
})
}
}
salsa::database_storage! {
struct DatabaseStorage for DatabaseStruct {
impl PanicSafelyDatabase {
fn one() for One;
fn panic_safely() for PanicSafely;
}
}
}
#[test]
fn should_panic_safely() {
let mut db = DatabaseStruct::default();
// Invoke `db.panic_safely() without having set `db.one`. `db.one` will
// default to 0 and we should catch the panic.
2018-10-31 19:59:00 +00:00
let result = panic::catch_unwind(AssertUnwindSafe({
2018-11-01 00:05:31 +00:00
let db = db.snapshot();
2018-10-31 19:59:00 +00:00
move || db.panic_safely()
}));
assert!(result.is_err());
// Set `db.one` to 1 and assert ok
db.query_mut(One).set((), 1);
let result = panic::catch_unwind(AssertUnwindSafe(|| db.panic_safely()));
assert!(result.is_ok())
}