mirror of
https://github.com/salsa-rs/salsa.git
synced 2025-01-27 07:04:35 +00:00
31 lines
859 B
Rust
31 lines
859 B
Rust
use crate::setup::{Input, ParDatabase, ParDatabaseImpl};
|
|
use salsa::{Database, ParallelDatabase};
|
|
|
|
/// Test where a read and a set are racing with one another.
|
|
/// Should be atomic.
|
|
#[test]
|
|
fn in_par_get_set_race() {
|
|
let db1 = ParDatabaseImpl::default();
|
|
let db2 = db1.fork();
|
|
|
|
db1.query(Input).set('a', 100);
|
|
db1.query(Input).set('b', 010);
|
|
db1.query(Input).set('c', 001);
|
|
|
|
let thread1 = std::thread::spawn(move || {
|
|
let v = db1.sum("abc");
|
|
v
|
|
});
|
|
|
|
let thread2 = std::thread::spawn(move || {
|
|
db2.query(Input).set('a', 1000);
|
|
db2.sum("a")
|
|
});
|
|
|
|
// If the 1st thread runs first, you get 111, otherwise you get
|
|
// 1011.
|
|
let value1 = thread1.join().unwrap();
|
|
assert!(value1 == 111 || value1 == 1011, "illegal result {}", value1);
|
|
|
|
assert_eq!(thread2.join().unwrap(), 1000);
|
|
}
|