salsa/tests/incremental/memoized_inputs.rs

65 lines
1.4 KiB
Rust
Raw Normal View History

2018-09-30 14:50:46 +00:00
use crate::implementation::{TestContext, TestContextImpl};
use salsa::Database;
2018-09-30 14:50:46 +00:00
salsa::query_prototype! {
crate trait MemoizedInputsContext: TestContext {
fn max(key: ()) -> usize {
type Max;
}
fn input1(key: ()) -> usize {
type Input1;
storage input;
}
fn input2(key: ()) -> usize {
type Input2;
storage input;
}
2018-09-30 14:50:46 +00:00
}
}
impl<DB: MemoizedInputsContext> salsa::QueryFunction<DB> for Max {
fn execute(db: &DB, (): ()) -> usize {
2018-10-05 08:54:51 +00:00
db.log().add("Max invoked");
std::cmp::max(db.input1(()), db.input2(()))
2018-09-30 14:50:46 +00:00
}
}
#[test]
fn revalidate() {
let db = &TestContextImpl::default();
2018-09-30 14:50:46 +00:00
let v = db.max(());
2018-09-30 14:50:46 +00:00
assert_eq!(v, 0);
db.assert_log(&["Max invoked"]);
2018-09-30 14:50:46 +00:00
let v = db.max(());
2018-09-30 14:50:46 +00:00
assert_eq!(v, 0);
db.assert_log(&[]);
2018-09-30 14:50:46 +00:00
db.query(Input1).set((), 44);
db.assert_log(&[]);
2018-09-30 14:50:46 +00:00
let v = db.max(());
2018-09-30 14:50:46 +00:00
assert_eq!(v, 44);
db.assert_log(&["Max invoked"]);
2018-09-30 14:50:46 +00:00
let v = db.max(());
2018-09-30 14:50:46 +00:00
assert_eq!(v, 44);
db.assert_log(&[]);
2018-09-30 14:50:46 +00:00
db.query(Input1).set((), 44);
db.assert_log(&[]);
db.query(Input2).set((), 66);
db.assert_log(&[]);
db.query(Input1).set((), 64);
db.assert_log(&[]);
2018-09-30 14:50:46 +00:00
let v = db.max(());
2018-09-30 14:50:46 +00:00
assert_eq!(v, 66);
db.assert_log(&["Max invoked"]);
2018-09-30 14:50:46 +00:00
let v = db.max(());
2018-09-30 14:50:46 +00:00
assert_eq!(v, 66);
db.assert_log(&[]);
2018-09-30 14:50:46 +00:00
}