2019-02-14 01:09:18 +00:00
|
|
|
use super::SlotClock;
|
|
|
|
use std::sync::RwLock;
|
2019-03-26 23:36:20 +00:00
|
|
|
use std::time::Duration;
|
2019-02-14 01:09:18 +00:00
|
|
|
use types::Slot;
|
|
|
|
|
|
|
|
#[derive(Debug, PartialEq)]
|
|
|
|
pub enum Error {}
|
|
|
|
|
|
|
|
/// Determines the present slot based upon the present system time.
|
|
|
|
pub struct TestingSlotClock {
|
|
|
|
slot: RwLock<u64>,
|
|
|
|
}
|
|
|
|
|
|
|
|
impl TestingSlotClock {
|
|
|
|
/// Create a new `TestingSlotClock`.
|
|
|
|
///
|
|
|
|
/// Returns an Error if `slot_duration_seconds == 0`.
|
|
|
|
pub fn new(slot: u64) -> TestingSlotClock {
|
|
|
|
TestingSlotClock {
|
|
|
|
slot: RwLock::new(slot),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn set_slot(&self, slot: u64) {
|
|
|
|
*self.slot.write().expect("TestingSlotClock poisoned.") = slot;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl SlotClock for TestingSlotClock {
|
|
|
|
type Error = Error;
|
|
|
|
|
|
|
|
fn present_slot(&self) -> Result<Option<Slot>, Error> {
|
|
|
|
let slot = *self.slot.read().expect("TestingSlotClock poisoned.");
|
|
|
|
Ok(Some(Slot::new(slot)))
|
|
|
|
}
|
2019-03-26 23:36:20 +00:00
|
|
|
|
|
|
|
/// Always returns a duration of 1 second.
|
|
|
|
fn duration_to_next_slot(&self) -> Result<Option<Duration>, Error> {
|
|
|
|
Ok(Some(Duration::from_secs(1)))
|
|
|
|
}
|
2019-02-14 01:09:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[cfg(test)]
|
|
|
|
mod tests {
|
|
|
|
use super::*;
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_slot_now() {
|
|
|
|
let clock = TestingSlotClock::new(10);
|
|
|
|
assert_eq!(clock.present_slot(), Ok(Some(Slot::new(10))));
|
|
|
|
clock.set_slot(123);
|
|
|
|
assert_eq!(clock.present_slot(), Ok(Some(Slot::new(123))));
|
|
|
|
}
|
|
|
|
}
|