blob: 968f14573e2cff0b2b2dfe9a1674d769bf3ddfa5 [file] [log] [blame]
use std::io;
use std::time::{Duration, Instant};
use polling::Poller;
#[test]
fn below_ms() -> io::Result<()> {
let poller = Poller::new()?;
let mut events = Vec::new();
let dur = Duration::from_micros(100);
let margin = Duration::from_micros(500);
let mut lowest = Duration::from_secs(1000);
for _ in 0..1_000 {
let now = Instant::now();
let n = poller.wait(&mut events, Some(dur))?;
let elapsed = now.elapsed();
assert_eq!(n, 0);
assert!(elapsed >= dur);
lowest = lowest.min(elapsed);
}
if cfg!(not(windows)) {
assert!(lowest < dur + margin);
}
Ok(())
}
#[test]
fn above_ms() -> io::Result<()> {
let poller = Poller::new()?;
let mut events = Vec::new();
let dur = Duration::from_micros(3_100);
let margin = Duration::from_micros(500);
let mut lowest = Duration::from_secs(1000);
for _ in 0..1_000 {
let now = Instant::now();
let n = poller.wait(&mut events, Some(dur))?;
let elapsed = now.elapsed();
assert_eq!(n, 0);
assert!(elapsed >= dur);
lowest = lowest.min(elapsed);
}
if cfg!(not(windows)) {
assert!(lowest < dur + margin);
}
Ok(())
}