blob: af0e852695e32980ea25be9910d38475fc3cd98e [file] [log] [blame]
use query_group_macro::query_group;
mod logger_db;
use expect_test::expect;
use logger_db::LoggerDb;
#[query_group]
pub trait HelloWorldDatabase: salsa::Database {
#[salsa::input]
fn input_string(&self) -> String;
#[salsa::invoke_interned(length_query)]
fn length_query(&self, key: ()) -> (usize, usize);
}
fn length_query(db: &dyn HelloWorldDatabase, _key: ()) -> (usize, usize) {
let len = db.input_string().len();
(len, len)
}
#[test]
fn query() {
let mut db = LoggerDb::default();
db.set_input_string(String::from("Hello, world!"));
let len = db.length_query(());
assert_eq!(len, (13, 13));
db.assert_logs(expect![[r#"
[
"salsa_event(WillCheckCancellation)",
"salsa_event(WillExecute { database_key: create_data_HelloWorldDatabase(Id(0)) })",
"salsa_event(WillCheckCancellation)",
"salsa_event(DidValidateMemoizedValue { database_key: create_data_HelloWorldDatabase(Id(0)) })",
"salsa_event(WillCheckCancellation)",
"salsa_event(WillExecute { database_key: length_query_shim(Id(800)) })",
"salsa_event(WillCheckCancellation)",
]"#]]);
}