forked from Proxmox/proxmox
proxmox-shared-memory: improve regression tests
Signed-off-by: Dietmar Maurer <dietmar@proxmox.com>
This commit is contained in:
parent
09dc3a4abc
commit
564703b195
@ -100,9 +100,11 @@ impl <T: Sized + Init> SharedMemory<T> {
|
|||||||
.ok_or_else(|| format_err!("bad path {:?}", path))?
|
.ok_or_else(|| format_err!("bad path {:?}", path))?
|
||||||
.to_owned();
|
.to_owned();
|
||||||
|
|
||||||
let statfs = nix::sys::statfs::statfs(&dir_name)?;
|
if !cfg!(test) {
|
||||||
if statfs.filesystem_type() != nix::sys::statfs::TMPFS_MAGIC {
|
let statfs = nix::sys::statfs::statfs(&dir_name)?;
|
||||||
bail!("path {:?} is not on tmpfs", dir_name);
|
if statfs.filesystem_type() != nix::sys::statfs::TMPFS_MAGIC {
|
||||||
|
bail!("path {:?} is not on tmpfs", dir_name);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
let oflag = OFlag::O_RDWR | OFlag::O_CLOEXEC;
|
let oflag = OFlag::O_RDWR | OFlag::O_CLOEXEC;
|
||||||
@ -116,7 +118,7 @@ impl <T: Sized + Init> SharedMemory<T> {
|
|||||||
}
|
}
|
||||||
Err(err) => {
|
Err(err) => {
|
||||||
if err.not_found() {
|
if err.not_found() {
|
||||||
// fall thrue - try to create the file
|
// fall true - try to create the file
|
||||||
} else {
|
} else {
|
||||||
bail!("open {:?} failed - {}", path, err);
|
bail!("open {:?} failed - {}", path, err);
|
||||||
}
|
}
|
||||||
@ -206,7 +208,9 @@ mod test {
|
|||||||
|
|
||||||
use super::*;
|
use super::*;
|
||||||
|
|
||||||
|
use std::sync::Arc;
|
||||||
use std::sync::atomic::AtomicU64;
|
use std::sync::atomic::AtomicU64;
|
||||||
|
use std::thread::spawn;
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
@ -251,17 +255,34 @@ mod test {
|
|||||||
#[test]
|
#[test]
|
||||||
fn test_shared_memory_mutex() -> Result<(), Error> {
|
fn test_shared_memory_mutex() -> Result<(), Error> {
|
||||||
|
|
||||||
create_path("/run/proxmox-shmem", None, None);
|
create_path("../target/testdata/", None, None);
|
||||||
|
|
||||||
let shared: SharedMemory<SingleMutexData> =
|
let shared: SharedMemory<SingleMutexData> =
|
||||||
SharedMemory::open(Path::new("/run/proxmox-shmem/test.shm"), CreateOptions::new())?;
|
SharedMemory::open(Path::new("../target/testdata/test1.shm"), CreateOptions::new())?;
|
||||||
|
|
||||||
let mut guard = shared.data().data.lock();
|
let shared = Arc::new(shared);
|
||||||
println!("DATA {:?}", *guard);
|
|
||||||
guard.count += 1;
|
|
||||||
println!("DATA {:?}", *guard);
|
|
||||||
|
|
||||||
//unimplemented!();
|
let start = shared.data().data.lock().count;
|
||||||
|
|
||||||
|
let mut threads: Vec<_> = (0..100)
|
||||||
|
.map(|_| {
|
||||||
|
let shared = shared.clone();
|
||||||
|
spawn(move || {
|
||||||
|
let mut guard = shared.data().data.lock();
|
||||||
|
println!("DATA {:?}", *guard);
|
||||||
|
guard.count += 1;
|
||||||
|
println!("DATA {:?}", *guard);
|
||||||
|
})
|
||||||
|
})
|
||||||
|
.collect();
|
||||||
|
|
||||||
|
for thread in threads {
|
||||||
|
thread.join().unwrap();
|
||||||
|
}
|
||||||
|
|
||||||
|
let end = shared.data().data.lock().count;
|
||||||
|
|
||||||
|
assert_eq!(end-start, 100);
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
@ -297,18 +318,39 @@ mod test {
|
|||||||
#[test]
|
#[test]
|
||||||
fn test_shared_memory_multi_mutex() -> Result<(), Error> {
|
fn test_shared_memory_multi_mutex() -> Result<(), Error> {
|
||||||
|
|
||||||
|
create_path("../target/testdata/", None, None);
|
||||||
|
|
||||||
let shared: SharedMemory<MultiMutexData> =
|
let shared: SharedMemory<MultiMutexData> =
|
||||||
SharedMemory::open(Path::new("/run/proxmox-shmem/test3.shm"), CreateOptions::new())?;
|
SharedMemory::open(Path::new("../target/testdata/test2.shm"), CreateOptions::new())?;
|
||||||
|
|
||||||
let mut guard = shared.data().block1.lock();
|
let shared = Arc::new(shared);
|
||||||
println!("BLOCK1 {:?}", *guard);
|
|
||||||
guard.count += 1;
|
|
||||||
|
|
||||||
let mut guard = shared.data().block2.lock();
|
let start1 = shared.data().block1.lock().count;
|
||||||
println!("BLOCK2 {:?}", *guard);
|
let start2 = shared.data().block2.lock().count;
|
||||||
guard.count += 2;
|
|
||||||
|
|
||||||
//unimplemented!();
|
let mut threads: Vec<_> = (0..100)
|
||||||
|
.map(|_| {
|
||||||
|
let shared = shared.clone();
|
||||||
|
spawn(move || {
|
||||||
|
let mut guard = shared.data().block1.lock();
|
||||||
|
println!("BLOCK1 {:?}", *guard);
|
||||||
|
guard.count += 1;
|
||||||
|
let mut guard = shared.data().block2.lock();
|
||||||
|
println!("BLOCK2 {:?}", *guard);
|
||||||
|
guard.count += 2;
|
||||||
|
})
|
||||||
|
})
|
||||||
|
.collect();
|
||||||
|
|
||||||
|
for thread in threads {
|
||||||
|
thread.join().unwrap();
|
||||||
|
}
|
||||||
|
|
||||||
|
let end1 = shared.data().block1.lock().count;
|
||||||
|
assert_eq!(end1-start1, 100);
|
||||||
|
|
||||||
|
let end2 = shared.data().block2.lock().count;
|
||||||
|
assert_eq!(end2-start2, 200);
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user