summaryrefslogtreecommitdiffstats
path: root/tokio-test
diff options
context:
space:
mode:
authorGeoff Shannon <geoffpshannon@gmail.com>2019-08-30 14:03:38 -0700
committerCarl Lerche <me@carllerche.com>2019-08-30 14:03:37 -0700
commit383bb0a14304c60e56750af3344455e21120105f (patch)
tree289e257dff587389b74c7ba96ef4764eca042226 /tokio-test
parentd2bd6f5002f806fd2293c8ad156cdf8f756313ec (diff)
test: fix assert format args (#1520)
Diffstat (limited to 'tokio-test')
-rw-r--r--tokio-test/src/macros.rs28
-rw-r--r--tokio-test/tests/macros.rs105
2 files changed, 99 insertions, 34 deletions
diff --git a/tokio-test/src/macros.rs b/tokio-test/src/macros.rs
index f563fe51..d8b3b2ba 100644
--- a/tokio-test/src/macros.rs
+++ b/tokio-test/src/macros.rs
@@ -33,13 +33,12 @@ macro_rules! assert_ready {
Pending => panic!("pending"),
}
}};
- ($e:expr, $($msg:tt),+) => {{
+ ($e:expr, $($msg:tt)+) => {{
use core::task::Poll::*;
match $e {
Ready(v) => v,
Pending => {
- let msg = format_args!($($msg),+);
- panic!("pending; {}", msg)
+ panic!("pending; {}", format_args!($($msg)+))
}
}
}};
@@ -76,10 +75,10 @@ macro_rules! assert_ready_ok {
let val = assert_ready!($e);
assert_ok!(val)
}};
- ($e:expr, $($msg:tt),+) => {{
+ ($e:expr, $($msg:tt)+) => {{
use tokio_test::{assert_ready, assert_ok};
- let val = assert_ready!($e, $($msg),*);
- assert_ok!(val, $($msg),*)
+ let val = assert_ready!($e, $($msg)*);
+ assert_ok!(val, $($msg)*)
}};
}
@@ -114,10 +113,10 @@ macro_rules! assert_ready_err {
let val = assert_ready!($e);
assert_err!(val)
}};
- ($e:expr, $($msg:tt),+) => {{
+ ($e:expr, $($msg:tt)+) => {{
use tokio_test::{assert_ready, assert_err};
- let val = assert_ready!($e, $($msg),*);
- assert_err!(val, $($msg),*)
+ let val = assert_ready!($e, $($msg)*);
+ assert_err!(val, $($msg)*)
}};
}
@@ -155,13 +154,12 @@ macro_rules! assert_pending {
Ready(v) => panic!("ready; value = {:?}", v),
}
}};
- ($e:expr, $($msg:tt),+) => {{
+ ($e:expr, $($msg:tt)+) => {{
use core::task::Poll::*;
match $e {
Pending => {}
Ready(v) => {
- let msg = format_args!($($msg),+);
- panic!("ready; value = {:?}; {}", v, msg)
+ panic!("ready; value = {:?}; {}", v, format_args!($($msg)+))
}
}
}};
@@ -198,9 +196,9 @@ macro_rules! assert_ready_eq {
assert_eq!(val, $expect)
};
- ($e:expr, $expect:expr, $($msg:tt),+) => {
- let val = $crate::assert_ready!($e);
- assert_eq!(val, $expect, $($msg),*)
+ ($e:expr, $expect:expr, $($msg:tt)+) => {
+ let val = $crate::assert_ready!($e, $($msg)*);
+ assert_eq!(val, $expect, $($msg)*)
};
}
diff --git a/tokio-test/tests/macros.rs b/tokio-test/tests/macros.rs
index a33fbad8..2183fc83 100644
--- a/tokio-test/tests/macros.rs
+++ b/tokio-test/tests/macros.rs
@@ -1,40 +1,107 @@
-#![cfg(feature = "broken")]
#![warn(rust_2018_idioms)]
-use futures::{future, Async, Future, Poll};
-use tokio_macros::{assert_not_ready, assert_ready, assert_ready_eq};
+use std::task::Poll;
+use tokio_test::{
+ assert_pending, assert_ready, assert_ready_eq, assert_ready_err, assert_ready_ok,
+};
+
+fn ready() -> Poll<()> {
+ Poll::Ready(())
+}
+
+fn ready_ok() -> Poll<Result<(), ()>> {
+ Poll::Ready(Ok(()))
+}
+
+fn ready_err() -> Poll<Result<(), ()>> {
+ Poll::Ready(Err(()))
+}
+
+fn pending() -> Poll<()> {
+ Poll::Pending
+}
+
+#[derive(Debug)]
+enum Test {
+ Data,
+}
#[test]
fn assert_ready() {
- let mut fut = future::ok::<(), ()>(());
- assert_ready!(fut.poll());
- let mut fut = future::ok::<(), ()>(());
- assert_ready!(fut.poll(), "some message");
+ let poll = ready();
+ assert_ready!(poll);
+ assert_ready!(poll, "some message");
+ assert_ready!(poll, "{:?}", ());
+ assert_ready!(poll, "{:?}", Test::Data);
}
#[test]
#[should_panic]
-fn assert_ready_err() {
- let mut fut = future::err::<(), ()>(());
- assert_ready!(fut.poll());
+fn assert_ready_on_pending() {
+ let poll = pending();
+ assert_ready!(poll);
+}
+
+#[test]
+fn assert_pending() {
+ let poll = pending();
+ assert_pending!(poll);
+ assert_pending!(poll, "some message");
+ assert_pending!(poll, "{:?}", ());
+ assert_pending!(poll, "{:?}", Test::Data);
+}
+
+#[test]
+#[should_panic]
+fn assert_pending_on_ready() {
+ let poll = ready();
+ assert_pending!(poll);
}
#[test]
-fn assert_not_ready() {
- let poll: Poll<(), ()> = Ok(Async::NotReady);
- assert_not_ready!(poll);
- assert_not_ready!(poll, "some message");
+fn assert_ready_ok() {
+ let poll = ready_ok();
+ assert_ready_ok!(poll);
+ assert_ready_ok!(poll, "some message");
+ assert_ready_ok!(poll, "{:?}", ());
+ assert_ready_ok!(poll, "{:?}", Test::Data);
}
#[test]
#[should_panic]
-fn assert_not_ready_err() {
- let mut fut = future::err::<(), ()>(());
- assert_not_ready!(fut.poll());
+fn assert_ok_on_err() {
+ let poll = ready_err();
+ assert_ready_ok!(poll);
+}
+
+#[test]
+fn assert_ready_err() {
+ let poll = ready_err();
+ assert_ready_err!(poll);
+ assert_ready_err!(poll, "some message");
+ assert_ready_err!(poll, "{:?}", ());
+ assert_ready_err!(poll, "{:?}", Test::Data);
+}
+
+#[test]
+#[should_panic]
+fn assert_err_on_ok() {
+ let poll = ready_ok();
+ assert_ready_err!(poll);
}
#[test]
fn assert_ready_eq() {
- let mut fut = future::ok::<(), ()>(());
- assert_ready_eq!(fut.poll(), ());
+ let poll = ready();
+ assert_ready_eq!(poll, ());
+ assert_ready_eq!(poll, (), "some message");
+ assert_ready_eq!(poll, (), "{:?}", ());
+ assert_ready_eq!(poll, (), "{:?}", Test::Data);
+}
+
+#[test]
+#[should_panic]
+fn assert_eq_on_not_eq() {
+ let poll = ready_err();
+ assert_ready_eq!(poll, Ok(()));
}