mirror of
https://github.com/rust-lang/rust-analyzer.git
synced 2025-09-28 11:20:54 +00:00
61 lines
1.7 KiB
Rust
61 lines
1.7 KiB
Rust
use std::sync::{Arc, Mutex};
|
|
|
|
#[salsa_macros::db]
|
|
#[derive(Default, Clone)]
|
|
pub(crate) struct LoggerDb {
|
|
storage: salsa::Storage<Self>,
|
|
logger: Logger,
|
|
}
|
|
|
|
#[derive(Default, Clone)]
|
|
struct Logger {
|
|
logs: Arc<Mutex<Vec<String>>>,
|
|
}
|
|
|
|
#[salsa_macros::db]
|
|
impl salsa::Database for LoggerDb {
|
|
fn salsa_event(&self, event: &dyn Fn() -> salsa::Event) {
|
|
let event = event();
|
|
match event.kind {
|
|
salsa::EventKind::WillExecute { .. }
|
|
| salsa::EventKind::WillCheckCancellation
|
|
| salsa::EventKind::DidValidateMemoizedValue { .. }
|
|
| salsa::EventKind::WillDiscardStaleOutput { .. }
|
|
| salsa::EventKind::DidDiscard { .. } => {
|
|
self.push_log(format!("salsa_event({:?})", event.kind));
|
|
}
|
|
_ => {}
|
|
}
|
|
}
|
|
}
|
|
|
|
impl LoggerDb {
|
|
/// Log an event from inside a tracked function.
|
|
pub(crate) fn push_log(&self, string: String) {
|
|
self.logger.logs.lock().unwrap().push(string);
|
|
}
|
|
|
|
/// Asserts what the (formatted) logs should look like,
|
|
/// clearing the logged events. This takes `&mut self` because
|
|
/// it is meant to be run from outside any tracked functions.
|
|
pub(crate) fn assert_logs(&self, expected: expect_test::Expect) {
|
|
let logs = std::mem::take(&mut *self.logger.logs.lock().unwrap());
|
|
expected.assert_eq(&format!("{logs:#?}"));
|
|
}
|
|
}
|
|
|
|
/// Test the logger database.
|
|
///
|
|
/// This test isn't very interesting, but it *does* remove a dead code warning.
|
|
#[test]
|
|
fn test_logger_db() {
|
|
let db = LoggerDb::default();
|
|
db.push_log("test".to_string());
|
|
db.assert_logs(expect_test::expect![
|
|
r#"
|
|
[
|
|
"test",
|
|
]"#
|
|
]);
|
|
}
|