mirror of
https://github.com/rust-lang/rust-analyzer.git
synced 2025-09-25 11:17:13 +00:00
51 lines
1.6 KiB
Rust
51 lines
1.6 KiB
Rust
mod logger_db;
|
|
use expect_test::expect;
|
|
use logger_db::LoggerDb;
|
|
|
|
use query_group_macro::query_group;
|
|
|
|
#[derive(Clone, Debug, PartialEq, Eq)]
|
|
pub struct Error;
|
|
|
|
#[query_group]
|
|
pub trait ResultDatabase: salsa::Database {
|
|
#[salsa::input]
|
|
fn input_string(&self) -> String;
|
|
|
|
fn length(&self, key: ()) -> Result<usize, Error>;
|
|
|
|
fn length2(&self, key: ()) -> Result<usize, Error>;
|
|
}
|
|
|
|
fn length(db: &dyn ResultDatabase, _key: ()) -> Result<usize, Error> {
|
|
Ok(db.input_string().len())
|
|
}
|
|
|
|
fn length2(db: &dyn ResultDatabase, _key: ()) -> Result<usize, Error> {
|
|
Ok(db.input_string().len())
|
|
}
|
|
|
|
#[test]
|
|
fn test_queries_with_results() {
|
|
let mut db = LoggerDb::default();
|
|
let input = "hello";
|
|
db.set_input_string(input.to_owned());
|
|
assert_eq!(db.length(()), Ok(input.len()));
|
|
assert_eq!(db.length2(()), Ok(input.len()));
|
|
|
|
db.assert_logs(expect![[r#"
|
|
[
|
|
"salsa_event(WillCheckCancellation)",
|
|
"salsa_event(WillExecute { database_key: create_data_ResultDatabase(Id(0)) })",
|
|
"salsa_event(WillCheckCancellation)",
|
|
"salsa_event(DidValidateMemoizedValue { database_key: create_data_ResultDatabase(Id(0)) })",
|
|
"salsa_event(WillCheckCancellation)",
|
|
"salsa_event(WillExecute { database_key: length_shim(Id(800)) })",
|
|
"salsa_event(WillCheckCancellation)",
|
|
"salsa_event(WillCheckCancellation)",
|
|
"salsa_event(WillCheckCancellation)",
|
|
"salsa_event(WillExecute { database_key: length2_shim(Id(c00)) })",
|
|
"salsa_event(WillCheckCancellation)",
|
|
]"#]]);
|
|
}
|