diff options
author | shuo <shuoli84@gmail.com> | 2020-04-12 22:05:03 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-04-12 16:05:03 +0200 |
commit | 060d22bd10ac66d91b70522138816c9bd05d5ead (patch) | |
tree | f98f2d4fb19a6e3f79d32f2b32a74bc3f11230c8 /tokio/tests/io_write_int.rs | |
parent | 8118f8f117a5b544f3bc6b3ce4e639a2a605afcb (diff) |
io: report error on zero-write in write_int (#2334)
* tokio-io: make write_i* same behavior as write_all when poll_write returns Ok(0)
Fixes: #2329
Co-authored-by: lishuo <lishuo.03@bytedance.com>
Diffstat (limited to 'tokio/tests/io_write_int.rs')
-rw-r--r-- | tokio/tests/io_write_int.rs | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/tokio/tests/io_write_int.rs b/tokio/tests/io_write_int.rs new file mode 100644 index 00000000..48a583d8 --- /dev/null +++ b/tokio/tests/io_write_int.rs @@ -0,0 +1,37 @@ +#![warn(rust_2018_idioms)] +#![cfg(feature = "full")] + +use tokio::io::{AsyncWrite, AsyncWriteExt}; + +use std::io; +use std::pin::Pin; +use std::task::{Context, Poll}; + +#[tokio::test] +async fn write_int_should_err_if_write_count_0() { + struct Wr {} + + impl AsyncWrite for Wr { + fn poll_write( + self: Pin<&mut Self>, + _cx: &mut Context<'_>, + _buf: &[u8], + ) -> Poll<io::Result<usize>> { + Ok(0).into() + } + + fn poll_flush(self: Pin<&mut Self>, _cx: &mut Context<'_>) -> Poll<io::Result<()>> { + Ok(()).into() + } + + fn poll_shutdown(self: Pin<&mut Self>, _cx: &mut Context<'_>) -> Poll<io::Result<()>> { + Ok(()).into() + } + } + + let mut wr = Wr {}; + + // should be ok just to test these 2, other cases actually expanded by same macro. + assert!(wr.write_i8(0).await.is_err()); + assert!(wr.write_i32(12).await.is_err()); +} |