futures_test/io/read/mod.rs
1//! Additional combinators for testing async readers.
2
3use futures_io::AsyncRead;
4
5pub use super::limited::Limited;
6pub use crate::assert_unmoved::AssertUnmoved;
7pub use crate::interleave_pending::InterleavePending;
8
9/// Additional combinators for testing async readers.
10pub trait AsyncReadTestExt: AsyncRead {
11 /// Asserts that the given is not moved after being polled.
12 ///
13 /// A check for movement is performed each time the reader is polled
14 /// and when `Drop` is called.
15 ///
16 /// Aside from keeping track of the location at which the reader was first
17 /// polled and providing assertions, this reader adds no runtime behavior
18 /// and simply delegates to the child reader.
19 fn assert_unmoved(self) -> AssertUnmoved<Self>
20 where
21 Self: Sized,
22 {
23 AssertUnmoved::new(self)
24 }
25
26 /// Introduces an extra [`Poll::Pending`](futures_core::task::Poll::Pending)
27 /// in between each read of the reader.
28 ///
29 /// # Examples
30 ///
31 /// ```
32 /// use core::pin::pin;
33 ///
34 /// use futures::task::Poll;
35 /// use futures::io::{AsyncRead, Cursor};
36 /// use futures_test::task::noop_context;
37 /// use futures_test::io::AsyncReadTestExt;
38 ///
39 /// let reader = Cursor::new(&[1, 2, 3]).interleave_pending();
40 /// let mut reader = pin!(reader);
41 ///
42 /// let mut cx = noop_context();
43 ///
44 /// let mut buf = [0, 0];
45 ///
46 /// assert_eq!(reader.as_mut().poll_read(&mut cx, &mut buf[..])?, Poll::Pending);
47 /// assert_eq!(reader.as_mut().poll_read(&mut cx, &mut buf[..])?, Poll::Ready(2));
48 /// assert_eq!(buf, [1, 2]);
49 /// assert_eq!(reader.as_mut().poll_read(&mut cx, &mut buf[..])?, Poll::Pending);
50 /// assert_eq!(reader.as_mut().poll_read(&mut cx, &mut buf[..])?, Poll::Ready(1));
51 /// assert_eq!(buf, [3, 2]);
52 /// assert_eq!(reader.as_mut().poll_read(&mut cx, &mut buf[..])?, Poll::Pending);
53 /// assert_eq!(reader.as_mut().poll_read(&mut cx, &mut buf[..])?, Poll::Ready(0));
54 ///
55 /// # Ok::<(), std::io::Error>(())
56 /// ```
57 ///
58 /// ## `AsyncBufRead`
59 ///
60 /// The returned reader will also implement `AsyncBufRead` if the underlying reader does.
61 ///
62 /// ```
63 /// use core::pin::pin;
64 ///
65 /// use futures::task::Poll;
66 /// use futures::io::{AsyncBufRead, Cursor};
67 /// use futures_test::task::noop_context;
68 /// use futures_test::io::AsyncReadTestExt;
69 ///
70 /// let reader = Cursor::new(&[1, 2, 3]).interleave_pending();
71 /// let mut reader = pin!(reader);
72 ///
73 /// let mut cx = noop_context();
74 ///
75 /// assert_eq!(reader.as_mut().poll_fill_buf(&mut cx)?, Poll::Pending);
76 /// assert_eq!(reader.as_mut().poll_fill_buf(&mut cx)?, Poll::Ready(&[1, 2, 3][..]));
77 /// reader.as_mut().consume(2);
78 /// assert_eq!(reader.as_mut().poll_fill_buf(&mut cx)?, Poll::Pending);
79 /// assert_eq!(reader.as_mut().poll_fill_buf(&mut cx)?, Poll::Ready(&[3][..]));
80 /// reader.as_mut().consume(1);
81 /// assert_eq!(reader.as_mut().poll_fill_buf(&mut cx)?, Poll::Pending);
82 /// assert_eq!(reader.as_mut().poll_fill_buf(&mut cx)?, Poll::Ready(&[][..]));
83 ///
84 /// # Ok::<(), std::io::Error>(())
85 /// ```
86 fn interleave_pending(self) -> InterleavePending<Self>
87 where
88 Self: Sized,
89 {
90 InterleavePending::new(self)
91 }
92
93 /// Limit the number of bytes allowed to be read on each call to `poll_read`.
94 ///
95 /// # Examples
96 ///
97 /// ```
98 /// use core::pin::pin;
99 ///
100 /// use futures::task::Poll;
101 /// use futures::io::{AsyncRead, Cursor};
102 /// use futures_test::task::noop_context;
103 /// use futures_test::io::AsyncReadTestExt;
104 ///
105 /// let reader = Cursor::new(&[1, 2, 3, 4, 5]).limited(2);
106 /// let mut reader = pin!(reader);
107 ///
108 /// let mut cx = noop_context();
109 ///
110 /// let mut buf = [0; 10];
111 ///
112 /// assert_eq!(reader.as_mut().poll_read(&mut cx, &mut buf)?, Poll::Ready(2));
113 /// assert_eq!(&buf[..2], &[1, 2]);
114 /// assert_eq!(reader.as_mut().poll_read(&mut cx, &mut buf)?, Poll::Ready(2));
115 /// assert_eq!(&buf[..2], &[3, 4]);
116 /// assert_eq!(reader.as_mut().poll_read(&mut cx, &mut buf)?, Poll::Ready(1));
117 /// assert_eq!(&buf[..1], &[5]);
118 ///
119 /// # Ok::<(), std::io::Error>(())
120 /// ```
121 fn limited(self, limit: usize) -> Limited<Self>
122 where
123 Self: Sized,
124 {
125 Limited::new(self, limit)
126 }
127}
128
129impl<R> AsyncReadTestExt for R where R: AsyncRead {}