move distinct tests into their own files to ease reading

This commit is contained in:
Niko Matsakis 2018-10-13 05:24:34 -04:00
parent fb5ba07290
commit 8da63ec029
4 changed files with 61 additions and 49 deletions

View file

@ -1,54 +1,9 @@
use crate::setup::{Input, Knobs, ParDatabase, ParDatabaseImpl, WithValue}; use crate::setup::{Input, Knobs, ParDatabase, ParDatabaseImpl, WithValue};
use salsa::Database; use salsa::{Database, ParallelDatabase};
use salsa::ParallelDatabase;
#[test]
fn in_par() {
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);
db1.query(Input).set('d', 200);
db1.query(Input).set('e', 020);
db1.query(Input).set('f', 002);
let thread1 = std::thread::spawn(move || db1.sum("abc"));
let thread2 = std::thread::spawn(move || db2.sum("def"));
assert_eq!(thread1.join().unwrap(), 111);
assert_eq!(thread2.join().unwrap(), 222);
}
#[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);
}
/// Add test where a call to `sum` is cancelled by a simultaneous
/// write. Check that we recompute the result in next revision, even
/// though none of the inputs have changed.
#[test] #[test]
fn in_par_get_set_cancellation() { fn in_par_get_set_cancellation() {
let db = ParDatabaseImpl::default(); let db = ParDatabaseImpl::default();

View file

@ -0,0 +1,24 @@
use crate::setup::{Input, ParDatabase, ParDatabaseImpl};
use salsa::{Database, ParallelDatabase};
/// Test two `sum` queries (on distinct keys) executing in different
/// threads. Really just a test that `fork` etc compiles.
#[test]
fn in_par_two_independent_queries() {
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);
db1.query(Input).set('d', 200);
db1.query(Input).set('e', 020);
db1.query(Input).set('f', 002);
let thread1 = std::thread::spawn(move || db1.sum("abc"));
let thread2 = std::thread::spawn(move || db2.sum("def"));
assert_eq!(thread1.join().unwrap(), 111);
assert_eq!(thread2.join().unwrap(), 222);
}

View file

@ -1,3 +1,5 @@
mod setup; mod setup;
mod cancellation; mod cancellation;
mod independent;
mod race;

31
tests/parallel/race.rs Normal file
View file

@ -0,0 +1,31 @@
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);
}