salsa/tests/gc/discard_values.rs
Niko Matsakis 8c133e7a4d make synthetic_write require &mut self (breaking change!)
This was an oversight before -- the current type implies that
one introduce a synthetic write (and hence a new revision) from
a `Frozen<DB>`! Not cool.
2019-09-27 05:50:16 -04:00

56 lines
1.3 KiB
Rust

use crate::db;
use crate::group::{FibonacciQuery, GcDatabase};
use salsa::debug::DebugQueryTable;
use salsa::{Database, Durability, SweepStrategy};
#[test]
fn sweep_default() {
let mut db = db::DatabaseImpl::default();
db.fibonacci(5);
let k: Vec<_> = db.query(FibonacciQuery).entries();
assert_eq!(k.len(), 6);
db.salsa_runtime_mut().synthetic_write(Durability::LOW);
db.fibonacci(5);
db.fibonacci(3);
// fibonacci is a constant, so it will not be invalidated,
// hence we keep 3 and 5 but remove the rest.
db.sweep_all(SweepStrategy::discard_outdated());
assert_keys! {
db,
FibonacciQuery => (3, 5),
}
// Even though we ran the sweep, 5 is still in cache
db.clear_log();
db.fibonacci(5);
db.assert_log(&[]);
// Same but we discard values this time.
db.sweep_all(
SweepStrategy::default()
.discard_values()
.sweep_all_revisions(),
);
db.sweep_all(SweepStrategy::discard_outdated());
assert_keys! {
db,
FibonacciQuery => (3, 5),
}
// Now we have to recompute
db.clear_log();
db.fibonacci(5);
db.assert_log(&[
"fibonacci(5)",
"fibonacci(4)",
"fibonacci(3)",
"fibonacci(2)",
"fibonacci(1)",
"fibonacci(0)",
]);
}