From b16d301dd9f2138b91a05e398a61d3ddeb8f6b7b Mon Sep 17 00:00:00 2001 From: Ralf Jung Date: Thu, 1 Sep 2022 12:30:11 +0200 Subject: [PATCH] test fast sleeping --- tests/pass/shims/time-with-isolation.rs | 25 +++++++++++++------------ 1 file changed, 13 insertions(+), 12 deletions(-) diff --git a/tests/pass/shims/time-with-isolation.rs b/tests/pass/shims/time-with-isolation.rs index 3366b77690d..7e6c74d71cb 100644 --- a/tests/pass/shims/time-with-isolation.rs +++ b/tests/pass/shims/time-with-isolation.rs @@ -1,21 +1,15 @@ use std::time::{Duration, Instant}; -fn duration_sanity(diff: Duration) { - // The virtual clock is deterministic and I got 29us on a 64-bit Linux machine. However, this - // changes according to the platform so we use an interval to be safe. This should be updated - // if `NANOSECONDS_PER_BASIC_BLOCK` changes. - assert!(diff.as_micros() > 10); - assert!(diff.as_micros() < 40); -} - fn test_sleep() { + // We sleep a *long* time here -- but the clock is virtual so the test should still pass quickly. let before = Instant::now(); - std::thread::sleep(Duration::from_millis(100)); + std::thread::sleep(Duration::from_secs(3600)); let after = Instant::now(); - assert!((after - before).as_millis() >= 100); + assert!((after - before).as_secs() >= 3600); } -fn main() { +/// Ensure that time passes even if we don't sleep (but just wor). +fn test_time_passes() { // Check `Instant`. let now1 = Instant::now(); // Do some work to make time pass. @@ -28,7 +22,14 @@ fn main() { let diff = now2.duration_since(now1); assert_eq!(now1 + diff, now2); assert_eq!(now2 - diff, now1); - duration_sanity(diff); + // The virtual clock is deterministic and I got 29us on a 64-bit Linux machine. However, this + // changes according to the platform so we use an interval to be safe. This should be updated + // if `NANOSECONDS_PER_BASIC_BLOCK` changes. + assert!(diff.as_micros() > 10); + assert!(diff.as_micros() < 40); +} +fn main() { + test_time_passes(); test_sleep(); }