extern crate futures;
extern crate tokio_executor;
extern crate tokio_timer;
#[macro_use]
mod support;
use support::*;
use tokio_timer::*;
use futures::{future, Future};
use futures::sync::oneshot;
#[test]
fn simultaneous_deadline_future_completion() {
mocked(|_, time| {
let fut = future::ok::<_, ()>(());
let mut fut = Deadline::new(fut, time.now());
assert_ready!(fut);
});
}
#[test]
fn completed_future_past_deadline() {
mocked(|_, time| {
let fut = future::ok::<_, ()>(());
let mut fut = Deadline::new(fut, time.now() - ms(1000));
assert_ready!(fut);
});
}
#[test]
fn future_and_deadline_in_future() {
mocked(|timer, time| {
let (tx, rx) = oneshot::channel();
let mut fut = Deadline::new(rx, time.now() + ms(100));
assert_not_ready!(fut);
advance(timer, ms(90));
assert_not_ready!(fut);
tx.send(()).unwrap();
assert_ready!(fut);
});
}
#[test]
fn deadline_now_elapses() {
mocked(|_, time| {
let fut = future::empty::<(), ()>();
let mut fut = Deadline::new(fut, time.now());
assert_elapsed!(fut);
});
}
#[test]
fn deadline_future_elapses() {
mocked(|timer, time| {
let fut = future::empty::<(), ()>();
let mut fut = Deadline::new(fut, time.now() + ms(300));
assert_not_ready!(fut);
advance(timer, ms(300));
assert_elapsed!(fut);
});
}
#[test]
fn future_errors_first() {
mocked(|_, time| {
let fut = future::err::<(), ()>(());
let mut fut = Deadline::new(fut, time.now() + ms(100));
assert!(fut.poll().unwrap_err().is_inner());
});
}