rust-analyzer/crates/ra-salsa/tests/incremental/memoized_inputs.rs

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

77 lines
1.6 KiB
Rust
Raw Normal View History

2024-02-07 15:29:46 +00:00
use crate::implementation::{TestContext, TestContextImpl};
2024-10-04 19:48:11 +00:00
#[ra_salsa::query_group(MemoizedInputs)]
2024-02-07 15:29:46 +00:00
pub(crate) trait MemoizedInputsContext: TestContext {
fn max(&self) -> usize;
2024-10-04 19:48:11 +00:00
#[ra_salsa::input]
2024-02-07 15:29:46 +00:00
fn input1(&self) -> usize;
2024-10-04 19:48:11 +00:00
#[ra_salsa::input]
2024-02-07 15:29:46 +00:00
fn input2(&self) -> usize;
}
fn max(db: &dyn MemoizedInputsContext) -> usize {
db.log().add("Max invoked");
std::cmp::max(db.input1(), db.input2())
}
#[test]
fn revalidate() {
let db = &mut TestContextImpl::default();
db.set_input1(0);
db.set_input2(0);
let v = db.max();
assert_eq!(v, 0);
db.assert_log(&["Max invoked"]);
let v = db.max();
assert_eq!(v, 0);
db.assert_log(&[]);
db.set_input1(44);
db.assert_log(&[]);
let v = db.max();
assert_eq!(v, 44);
db.assert_log(&["Max invoked"]);
let v = db.max();
assert_eq!(v, 44);
db.assert_log(&[]);
db.set_input1(44);
db.assert_log(&[]);
db.set_input2(66);
db.assert_log(&[]);
db.set_input1(64);
db.assert_log(&[]);
let v = db.max();
assert_eq!(v, 66);
db.assert_log(&["Max invoked"]);
let v = db.max();
assert_eq!(v, 66);
db.assert_log(&[]);
}
/// Test that invoking `set` on an input with the same value still
/// triggers a new revision.
#[test]
fn set_after_no_change() {
let db = &mut TestContextImpl::default();
db.set_input2(0);
db.set_input1(44);
let v = db.max();
assert_eq!(v, 44);
db.assert_log(&["Max invoked"]);
db.set_input1(44);
let v = db.max();
assert_eq!(v, 44);
db.assert_log(&["Max invoked"]);
}