Merge pull request #2420 from chrisprice/mock-driver
Extend mock time driver to support alarms
This commit is contained in:
		
						commit
						0027a76bb6
					
				
							
								
								
									
										2
									
								
								.github/ci/test.sh
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/ci/test.sh
									
									
									
									
										vendored
									
									
								
							| @ -11,7 +11,7 @@ export CARGO_TARGET_DIR=/ci/cache/target | |||||||
| cargo test --manifest-path ./embassy-sync/Cargo.toml  | cargo test --manifest-path ./embassy-sync/Cargo.toml  | ||||||
| cargo test --manifest-path ./embassy-embedded-hal/Cargo.toml  | cargo test --manifest-path ./embassy-embedded-hal/Cargo.toml  | ||||||
| cargo test --manifest-path ./embassy-hal-internal/Cargo.toml  | cargo test --manifest-path ./embassy-hal-internal/Cargo.toml  | ||||||
| cargo test --manifest-path ./embassy-time/Cargo.toml --features generic-queue | cargo test --manifest-path ./embassy-time/Cargo.toml --features generic-queue,mock-driver | ||||||
| 
 | 
 | ||||||
| cargo test --manifest-path ./embassy-boot/boot/Cargo.toml | cargo test --manifest-path ./embassy-boot/boot/Cargo.toml | ||||||
| cargo test --manifest-path ./embassy-boot/boot/Cargo.toml --features ed25519-dalek | cargo test --manifest-path ./embassy-boot/boot/Cargo.toml --features ed25519-dalek | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								ci.sh
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								ci.sh
									
									
									
									
									
								
							| @ -34,7 +34,7 @@ cargo batch  \ | |||||||
|     --- build --release --manifest-path embassy-executor/Cargo.toml --target riscv32imac-unknown-none-elf --features arch-riscv32,executor-thread \ |     --- build --release --manifest-path embassy-executor/Cargo.toml --target riscv32imac-unknown-none-elf --features arch-riscv32,executor-thread \ | ||||||
|     --- build --release --manifest-path embassy-executor/Cargo.toml --target riscv32imac-unknown-none-elf --features arch-riscv32,executor-thread,integrated-timers \ |     --- build --release --manifest-path embassy-executor/Cargo.toml --target riscv32imac-unknown-none-elf --features arch-riscv32,executor-thread,integrated-timers \ | ||||||
|     --- build --release --manifest-path embassy-sync/Cargo.toml --target thumbv6m-none-eabi --features defmt \ |     --- build --release --manifest-path embassy-sync/Cargo.toml --target thumbv6m-none-eabi --features defmt \ | ||||||
|     --- build --release --manifest-path embassy-time/Cargo.toml --target thumbv6m-none-eabi --features defmt,defmt-timestamp-uptime,tick-hz-32_768,generic-queue-8 \ |     --- build --release --manifest-path embassy-time/Cargo.toml --target thumbv6m-none-eabi --features defmt,defmt-timestamp-uptime,generic-queue-8,mock-driver \ | ||||||
|     --- build --release --manifest-path embassy-net/Cargo.toml --target thumbv7em-none-eabi --features defmt,tcp,udp,dns,proto-ipv4,medium-ethernet \ |     --- build --release --manifest-path embassy-net/Cargo.toml --target thumbv7em-none-eabi --features defmt,tcp,udp,dns,proto-ipv4,medium-ethernet \ | ||||||
|     --- build --release --manifest-path embassy-net/Cargo.toml --target thumbv7em-none-eabi --features defmt,tcp,udp,dns,proto-ipv4,igmp,medium-ethernet \ |     --- build --release --manifest-path embassy-net/Cargo.toml --target thumbv7em-none-eabi --features defmt,tcp,udp,dns,proto-ipv4,igmp,medium-ethernet \ | ||||||
|     --- build --release --manifest-path embassy-net/Cargo.toml --target thumbv7em-none-eabi --features defmt,tcp,udp,dns,dhcpv4,medium-ethernet \ |     --- build --release --manifest-path embassy-net/Cargo.toml --target thumbv7em-none-eabi --features defmt,tcp,udp,dns,dhcpv4,medium-ethernet \ | ||||||
|  | |||||||
| @ -42,7 +42,6 @@ | |||||||
| //! use embassy_time::driver::{Driver, AlarmHandle};
 | //! use embassy_time::driver::{Driver, AlarmHandle};
 | ||||||
| //!
 | //!
 | ||||||
| //! struct MyDriver{} // not public!
 | //! struct MyDriver{} // not public!
 | ||||||
| //! embassy_time::time_driver_impl!(static DRIVER: MyDriver = MyDriver{});
 |  | ||||||
| //!
 | //!
 | ||||||
| //! impl Driver for MyDriver {
 | //! impl Driver for MyDriver {
 | ||||||
| //!     fn now(&self) -> u64 {
 | //!     fn now(&self) -> u64 {
 | ||||||
| @ -59,6 +58,9 @@ | |||||||
| //!     }
 | //!     }
 | ||||||
| //! }
 | //! }
 | ||||||
| //! ```
 | //! ```
 | ||||||
|  | //! ```ignore
 | ||||||
|  | //! embassy_time::time_driver_impl!(static DRIVER: MyDriver = MyDriver{});
 | ||||||
|  | //! ```
 | ||||||
| 
 | 
 | ||||||
| /// Alarm handle, assigned by the driver.
 | /// Alarm handle, assigned by the driver.
 | ||||||
| #[derive(Clone, Copy)] | #[derive(Clone, Copy)] | ||||||
|  | |||||||
| @ -1,4 +1,4 @@ | |||||||
| use core::cell::Cell; | use core::cell::RefCell; | ||||||
| 
 | 
 | ||||||
| use critical_section::Mutex as CsMutex; | use critical_section::Mutex as CsMutex; | ||||||
| 
 | 
 | ||||||
| @ -8,7 +8,7 @@ use crate::{Duration, Instant}; | |||||||
| /// A mock driver that can be manually advanced.
 | /// A mock driver that can be manually advanced.
 | ||||||
| /// This is useful for testing code that works with [`Instant`] and [`Duration`].
 | /// This is useful for testing code that works with [`Instant`] and [`Duration`].
 | ||||||
| ///
 | ///
 | ||||||
| /// This driver cannot currently be used to test runtime functionality, such as
 | /// This driver can also be used to test runtime functionality, such as
 | ||||||
| /// timers, delays, etc.
 | /// timers, delays, etc.
 | ||||||
| ///
 | ///
 | ||||||
| /// # Example
 | /// # Example
 | ||||||
| @ -26,43 +26,196 @@ use crate::{Duration, Instant}; | |||||||
| ///     assert_eq!(true, has_a_second_passed(reference));
 | ///     assert_eq!(true, has_a_second_passed(reference));
 | ||||||
| /// }
 | /// }
 | ||||||
| /// ```
 | /// ```
 | ||||||
| pub struct MockDriver { | pub struct MockDriver(CsMutex<RefCell<InnerMockDriver>>); | ||||||
|     now: CsMutex<Cell<Instant>>, |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| crate::time_driver_impl!(static DRIVER: MockDriver = MockDriver { | crate::time_driver_impl!(static DRIVER: MockDriver = MockDriver::new()); | ||||||
|     now: CsMutex::new(Cell::new(Instant::from_ticks(0))), |  | ||||||
| }); |  | ||||||
| 
 | 
 | ||||||
| impl MockDriver { | impl MockDriver { | ||||||
|  |     /// Creates a new mock driver.
 | ||||||
|  |     pub const fn new() -> Self { | ||||||
|  |         Self(CsMutex::new(RefCell::new(InnerMockDriver::new()))) | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     /// Gets a reference to the global mock driver.
 |     /// Gets a reference to the global mock driver.
 | ||||||
|     pub fn get() -> &'static MockDriver { |     pub fn get() -> &'static MockDriver { | ||||||
|         &DRIVER |         &DRIVER | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /// Advances the time by the specified [`Duration`].
 |     /// Resets the internal state of the mock driver
 | ||||||
|     pub fn advance(&self, duration: Duration) { |     /// This will clear and deallocate all alarms, and reset the current time to 0.
 | ||||||
|  |     pub fn reset(&self) { | ||||||
|         critical_section::with(|cs| { |         critical_section::with(|cs| { | ||||||
|             let now = self.now.borrow(cs).get().as_ticks(); |             self.0.borrow(cs).replace(InnerMockDriver::new()); | ||||||
|             self.now.borrow(cs).set(Instant::from_ticks(now + duration.as_ticks())); |  | ||||||
|         }); |         }); | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     /// Advances the time by the specified [`Duration`].
 | ||||||
|  |     /// Calling any alarm callbacks that are due.
 | ||||||
|  |     pub fn advance(&self, duration: Duration) { | ||||||
|  |         let notify = { | ||||||
|  |             critical_section::with(|cs| { | ||||||
|  |                 let mut inner = self.0.borrow_ref_mut(cs); | ||||||
|  | 
 | ||||||
|  |                 inner.now += duration; | ||||||
|  | 
 | ||||||
|  |                 let now = inner.now.as_ticks(); | ||||||
|  | 
 | ||||||
|  |                 inner | ||||||
|  |                     .alarm | ||||||
|  |                     .as_mut() | ||||||
|  |                     .filter(|alarm| alarm.timestamp <= now) | ||||||
|  |                     .map(|alarm| { | ||||||
|  |                         alarm.timestamp = u64::MAX; | ||||||
|  | 
 | ||||||
|  |                         (alarm.callback, alarm.ctx) | ||||||
|  |                     }) | ||||||
|  |             }) | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |         if let Some((callback, ctx)) = notify { | ||||||
|  |             (callback)(ctx); | ||||||
|  |         } | ||||||
|  |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| impl Driver for MockDriver { | impl Driver for MockDriver { | ||||||
|     fn now(&self) -> u64 { |     fn now(&self) -> u64 { | ||||||
|         critical_section::with(|cs| self.now.borrow(cs).get().as_ticks() as u64) |         critical_section::with(|cs| self.0.borrow_ref(cs).now).as_ticks() | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     unsafe fn allocate_alarm(&self) -> Option<AlarmHandle> { |     unsafe fn allocate_alarm(&self) -> Option<AlarmHandle> { | ||||||
|         unimplemented!("MockDriver does not support runtime features that require an executor"); |         critical_section::with(|cs| { | ||||||
|  |             let mut inner = self.0.borrow_ref_mut(cs); | ||||||
|  | 
 | ||||||
|  |             if inner.alarm.is_some() { | ||||||
|  |                 None | ||||||
|  |             } else { | ||||||
|  |                 inner.alarm.replace(AlarmState::new()); | ||||||
|  | 
 | ||||||
|  |                 Some(AlarmHandle::new(0)) | ||||||
|  |             } | ||||||
|  |         }) | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     fn set_alarm_callback(&self, _alarm: AlarmHandle, _callback: fn(*mut ()), _ctx: *mut ()) { |     fn set_alarm_callback(&self, _alarm: AlarmHandle, callback: fn(*mut ()), ctx: *mut ()) { | ||||||
|         unimplemented!("MockDriver does not support runtime features that require an executor"); |         critical_section::with(|cs| { | ||||||
|  |             let mut inner = self.0.borrow_ref_mut(cs); | ||||||
|  | 
 | ||||||
|  |             let Some(alarm) = inner.alarm.as_mut() else { | ||||||
|  |                 panic!("Alarm not allocated"); | ||||||
|  |             }; | ||||||
|  | 
 | ||||||
|  |             alarm.callback = callback; | ||||||
|  |             alarm.ctx = ctx; | ||||||
|  |         }); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     fn set_alarm(&self, _alarm: AlarmHandle, _timestamp: u64) -> bool { |     fn set_alarm(&self, _alarm: AlarmHandle, timestamp: u64) -> bool { | ||||||
|         unimplemented!("MockDriver does not support runtime features that require an executor"); |         critical_section::with(|cs| { | ||||||
|  |             let mut inner = self.0.borrow_ref_mut(cs); | ||||||
|  | 
 | ||||||
|  |             if timestamp <= inner.now.as_ticks() { | ||||||
|  |                 false | ||||||
|  |             } else { | ||||||
|  |                 let Some(alarm) = inner.alarm.as_mut() else { | ||||||
|  |                     panic!("Alarm not allocated"); | ||||||
|  |                 }; | ||||||
|  | 
 | ||||||
|  |                 alarm.timestamp = timestamp; | ||||||
|  |                 true | ||||||
|  |             } | ||||||
|  |         }) | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | struct InnerMockDriver { | ||||||
|  |     now: Instant, | ||||||
|  |     alarm: Option<AlarmState>, | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | impl InnerMockDriver { | ||||||
|  |     const fn new() -> Self { | ||||||
|  |         Self { | ||||||
|  |             now: Instant::from_ticks(0), | ||||||
|  |             alarm: None, | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | struct AlarmState { | ||||||
|  |     timestamp: u64, | ||||||
|  |     callback: fn(*mut ()), | ||||||
|  |     ctx: *mut (), | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | impl AlarmState { | ||||||
|  |     const fn new() -> Self { | ||||||
|  |         Self { | ||||||
|  |             timestamp: u64::MAX, | ||||||
|  |             callback: Self::noop, | ||||||
|  |             ctx: core::ptr::null_mut(), | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     fn noop(_ctx: *mut ()) {} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | unsafe impl Send for AlarmState {} | ||||||
|  | 
 | ||||||
|  | #[cfg(test)] | ||||||
|  | mod tests { | ||||||
|  |     use serial_test::serial; | ||||||
|  | 
 | ||||||
|  |     use super::*; | ||||||
|  | 
 | ||||||
|  |     fn setup() { | ||||||
|  |         DRIVER.reset(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     #[test] | ||||||
|  |     #[serial] | ||||||
|  |     fn test_advance() { | ||||||
|  |         setup(); | ||||||
|  | 
 | ||||||
|  |         let driver = MockDriver::get(); | ||||||
|  |         let reference = driver.now(); | ||||||
|  |         driver.advance(Duration::from_secs(1)); | ||||||
|  |         assert_eq!(Duration::from_secs(1).as_ticks(), driver.now() - reference); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     #[test] | ||||||
|  |     #[serial] | ||||||
|  |     fn test_set_alarm_not_in_future() { | ||||||
|  |         setup(); | ||||||
|  | 
 | ||||||
|  |         let driver = MockDriver::get(); | ||||||
|  |         let alarm = unsafe { AlarmHandle::new(0) }; | ||||||
|  |         assert_eq!(false, driver.set_alarm(alarm, driver.now())); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     #[test] | ||||||
|  |     #[serial] | ||||||
|  |     fn test_alarm() { | ||||||
|  |         setup(); | ||||||
|  | 
 | ||||||
|  |         let driver = MockDriver::get(); | ||||||
|  |         let alarm = unsafe { driver.allocate_alarm() }.expect("No alarms available"); | ||||||
|  |         static mut CALLBACK_CALLED: bool = false; | ||||||
|  |         let ctx = &mut () as *mut (); | ||||||
|  |         driver.set_alarm_callback(alarm, |_| unsafe { CALLBACK_CALLED = true }, ctx); | ||||||
|  |         driver.set_alarm(alarm, driver.now() + 1); | ||||||
|  |         assert_eq!(false, unsafe { CALLBACK_CALLED }); | ||||||
|  |         driver.advance(Duration::from_secs(1)); | ||||||
|  |         assert_eq!(true, unsafe { CALLBACK_CALLED }); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     #[test] | ||||||
|  |     #[serial] | ||||||
|  |     fn test_allocate_alarm() { | ||||||
|  |         setup(); | ||||||
|  | 
 | ||||||
|  |         let driver = MockDriver::get(); | ||||||
|  |         assert!(unsafe { driver.allocate_alarm() }.is_some()); | ||||||
|  |         assert!(unsafe { driver.allocate_alarm() }.is_none()); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -23,7 +23,6 @@ | |||||||
| //! use embassy_time::queue::{TimerQueue};
 | //! use embassy_time::queue::{TimerQueue};
 | ||||||
| //!
 | //!
 | ||||||
| //! struct MyTimerQueue{}; // not public!
 | //! struct MyTimerQueue{}; // not public!
 | ||||||
| //! embassy_time::timer_queue_impl!(static QUEUE: MyTimerQueue = MyTimerQueue{});
 |  | ||||||
| //!
 | //!
 | ||||||
| //! impl TimerQueue for MyTimerQueue {
 | //! impl TimerQueue for MyTimerQueue {
 | ||||||
| //!     fn schedule_wake(&'static self, at: Instant, waker: &Waker) {
 | //!     fn schedule_wake(&'static self, at: Instant, waker: &Waker) {
 | ||||||
| @ -31,6 +30,9 @@ | |||||||
| //!     }
 | //!     }
 | ||||||
| //! }
 | //! }
 | ||||||
| //! ```
 | //! ```
 | ||||||
|  | //! ```ignore
 | ||||||
|  | //! embassy_time::timer_queue_impl!(static QUEUE: MyTimerQueue = MyTimerQueue{});
 | ||||||
|  | //! ```
 | ||||||
| use core::task::Waker; | use core::task::Waker; | ||||||
| 
 | 
 | ||||||
| use crate::Instant; | use crate::Instant; | ||||||
|  | |||||||
| @ -175,103 +175,17 @@ impl TimerQueue for Queue { | |||||||
| crate::timer_queue_impl!(static QUEUE: Queue = Queue::new()); | crate::timer_queue_impl!(static QUEUE: Queue = Queue::new()); | ||||||
| 
 | 
 | ||||||
| #[cfg(test)] | #[cfg(test)] | ||||||
|  | #[cfg(feature = "mock-driver")] | ||||||
| mod tests { | mod tests { | ||||||
|     use core::cell::Cell; |     use core::cell::Cell; | ||||||
|     use core::task::{RawWaker, RawWakerVTable, Waker}; |     use core::task::{RawWaker, RawWakerVTable, Waker}; | ||||||
|     use std::rc::Rc; |     use std::rc::Rc; | ||||||
|     use std::sync::Mutex; |  | ||||||
| 
 | 
 | ||||||
|     use serial_test::serial; |     use serial_test::serial; | ||||||
| 
 | 
 | ||||||
|     use crate::driver::{AlarmHandle, Driver}; |     use crate::driver_mock::MockDriver; | ||||||
|     use crate::queue_generic::QUEUE; |     use crate::queue_generic::QUEUE; | ||||||
|     use crate::Instant; |     use crate::{Duration, Instant}; | ||||||
| 
 |  | ||||||
|     struct InnerTestDriver { |  | ||||||
|         now: u64, |  | ||||||
|         alarm: u64, |  | ||||||
|         callback: fn(*mut ()), |  | ||||||
|         ctx: *mut (), |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     impl InnerTestDriver { |  | ||||||
|         const fn new() -> Self { |  | ||||||
|             Self { |  | ||||||
|                 now: 0, |  | ||||||
|                 alarm: u64::MAX, |  | ||||||
|                 callback: Self::noop, |  | ||||||
|                 ctx: core::ptr::null_mut(), |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         fn noop(_ctx: *mut ()) {} |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     unsafe impl Send for InnerTestDriver {} |  | ||||||
| 
 |  | ||||||
|     struct TestDriver(Mutex<InnerTestDriver>); |  | ||||||
| 
 |  | ||||||
|     impl TestDriver { |  | ||||||
|         const fn new() -> Self { |  | ||||||
|             Self(Mutex::new(InnerTestDriver::new())) |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         fn reset(&self) { |  | ||||||
|             *self.0.lock().unwrap() = InnerTestDriver::new(); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         fn set_now(&self, now: u64) { |  | ||||||
|             let notify = { |  | ||||||
|                 let mut inner = self.0.lock().unwrap(); |  | ||||||
| 
 |  | ||||||
|                 if inner.now < now { |  | ||||||
|                     inner.now = now; |  | ||||||
| 
 |  | ||||||
|                     if inner.alarm <= now { |  | ||||||
|                         inner.alarm = u64::MAX; |  | ||||||
| 
 |  | ||||||
|                         Some((inner.callback, inner.ctx)) |  | ||||||
|                     } else { |  | ||||||
|                         None |  | ||||||
|                     } |  | ||||||
|                 } else { |  | ||||||
|                     panic!("Going back in time?"); |  | ||||||
|                 } |  | ||||||
|             }; |  | ||||||
| 
 |  | ||||||
|             if let Some((callback, ctx)) = notify { |  | ||||||
|                 (callback)(ctx); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     impl Driver for TestDriver { |  | ||||||
|         fn now(&self) -> u64 { |  | ||||||
|             self.0.lock().unwrap().now |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         unsafe fn allocate_alarm(&self) -> Option<AlarmHandle> { |  | ||||||
|             Some(AlarmHandle::new(0)) |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         fn set_alarm_callback(&self, _alarm: AlarmHandle, callback: fn(*mut ()), ctx: *mut ()) { |  | ||||||
|             let mut inner = self.0.lock().unwrap(); |  | ||||||
| 
 |  | ||||||
|             inner.callback = callback; |  | ||||||
|             inner.ctx = ctx; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         fn set_alarm(&self, _alarm: AlarmHandle, timestamp: u64) -> bool { |  | ||||||
|             let mut inner = self.0.lock().unwrap(); |  | ||||||
| 
 |  | ||||||
|             if timestamp <= inner.now { |  | ||||||
|                 false |  | ||||||
|             } else { |  | ||||||
|                 inner.alarm = timestamp; |  | ||||||
|                 true |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| 
 | 
 | ||||||
|     struct TestWaker { |     struct TestWaker { | ||||||
|         pub awoken: Rc<Cell<bool>>, |         pub awoken: Rc<Cell<bool>>, | ||||||
| @ -312,10 +226,8 @@ mod tests { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     crate::time_driver_impl!(static DRIVER: TestDriver = TestDriver::new()); |  | ||||||
| 
 |  | ||||||
|     fn setup() { |     fn setup() { | ||||||
|         DRIVER.reset(); |         MockDriver::get().reset(); | ||||||
|         critical_section::with(|cs| *QUEUE.inner.borrow_ref_mut(cs) = None); |         critical_section::with(|cs| *QUEUE.inner.borrow_ref_mut(cs) = None); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -382,13 +294,13 @@ mod tests { | |||||||
| 
 | 
 | ||||||
|         assert!(!waker.awoken.get()); |         assert!(!waker.awoken.get()); | ||||||
| 
 | 
 | ||||||
|         DRIVER.set_now(Instant::from_secs(99).as_ticks()); |         MockDriver::get().advance(Duration::from_secs(99)); | ||||||
| 
 | 
 | ||||||
|         assert!(!waker.awoken.get()); |         assert!(!waker.awoken.get()); | ||||||
| 
 | 
 | ||||||
|         assert_eq!(queue_len(), 1); |         assert_eq!(queue_len(), 1); | ||||||
| 
 | 
 | ||||||
|         DRIVER.set_now(Instant::from_secs(100).as_ticks()); |         MockDriver::get().advance(Duration::from_secs(1)); | ||||||
| 
 | 
 | ||||||
|         assert!(waker.awoken.get()); |         assert!(waker.awoken.get()); | ||||||
| 
 | 
 | ||||||
| @ -404,7 +316,7 @@ mod tests { | |||||||
| 
 | 
 | ||||||
|         QUEUE.schedule_wake(Instant::from_secs(100), &waker.waker); |         QUEUE.schedule_wake(Instant::from_secs(100), &waker.waker); | ||||||
| 
 | 
 | ||||||
|         DRIVER.set_now(Instant::from_secs(50).as_ticks()); |         MockDriver::get().advance(Duration::from_secs(50)); | ||||||
| 
 | 
 | ||||||
|         let waker2 = TestWaker::new(); |         let waker2 = TestWaker::new(); | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user