salsa/tests/interned-struct-with-lifetime.rs

59 lines
1.3 KiB
Rust
Raw Normal View History

2024-05-16 09:18:56 +00:00
//! Test that a `tracked` fn on a `salsa::input`
//! compiles and executes successfully.
use salsa::DebugWithDb;
2024-06-18 07:40:21 +00:00
mod common;
use common::{HasLogger, Logger};
2024-05-16 09:18:56 +00:00
use expect_test::expect;
use test_log::test;
#[salsa::jar(db = Db)]
struct Jar(InternedString<'_>, InternedPair<'_>, intern_stuff);
trait Db: salsa::DbWithJar<Jar> + HasLogger {}
#[salsa::interned]
struct InternedString<'db> {
data: String,
}
#[salsa::interned]
struct InternedPair<'db> {
data: (InternedString<'db>, InternedString<'db>),
}
#[salsa::tracked]
fn intern_stuff(db: &dyn Db) -> String {
2024-05-30 12:23:42 +00:00
let s1 = InternedString::new(db, "Hello, ".to_string());
let s2 = InternedString::new(db, "World, ".to_string());
2024-05-16 09:18:56 +00:00
let s3 = InternedPair::new(db, (s1, s2));
format!("{:?}", s3.debug(db))
}
#[salsa::db(Jar)]
#[derive(Default)]
struct Database {
storage: salsa::Storage<Self>,
logger: Logger,
}
impl salsa::Database for Database {}
impl Db for Database {}
impl HasLogger for Database {
fn logger(&self) -> &Logger {
&self.logger
}
}
#[test]
fn execute() {
let mut db = Database::default();
expect![[r#"
"InternedPair { [salsa id]: 0, data: (InternedString { [salsa id]: 0, data: \"Hello, \" }, InternedString { [salsa id]: 1, data: \"World, \" }) }"
"#]].assert_debug_eq(&intern_stuff(&db));
db.assert_logs(expect!["[]"]);
}