Vendor dependencies
Let's see how I like this workflow.
This commit is contained in:
parent
34d1830413
commit
9c435dc440
7500 changed files with 1665121 additions and 99 deletions
79
vendor/tokio/tests/io_split.rs
vendored
Normal file
79
vendor/tokio/tests/io_split.rs
vendored
Normal file
|
|
@ -0,0 +1,79 @@
|
|||
#![warn(rust_2018_idioms)]
|
||||
#![cfg(all(feature = "full", not(tokio_wasi)))] // Wasi does not support panic recovery
|
||||
|
||||
use tokio::io::{split, AsyncRead, AsyncWrite, ReadBuf, ReadHalf, WriteHalf};
|
||||
|
||||
use std::io;
|
||||
use std::pin::Pin;
|
||||
use std::task::{Context, Poll};
|
||||
|
||||
struct RW;
|
||||
|
||||
impl AsyncRead for RW {
|
||||
fn poll_read(
|
||||
self: Pin<&mut Self>,
|
||||
_cx: &mut Context<'_>,
|
||||
buf: &mut ReadBuf<'_>,
|
||||
) -> Poll<io::Result<()>> {
|
||||
buf.put_slice(&[b'z']);
|
||||
Poll::Ready(Ok(()))
|
||||
}
|
||||
}
|
||||
|
||||
impl AsyncWrite for RW {
|
||||
fn poll_write(
|
||||
self: Pin<&mut Self>,
|
||||
_cx: &mut Context<'_>,
|
||||
_buf: &[u8],
|
||||
) -> Poll<Result<usize, io::Error>> {
|
||||
Poll::Ready(Ok(1))
|
||||
}
|
||||
|
||||
fn poll_flush(self: Pin<&mut Self>, _cx: &mut Context<'_>) -> Poll<Result<(), io::Error>> {
|
||||
Poll::Ready(Ok(()))
|
||||
}
|
||||
|
||||
fn poll_shutdown(self: Pin<&mut Self>, _cx: &mut Context<'_>) -> Poll<Result<(), io::Error>> {
|
||||
Poll::Ready(Ok(()))
|
||||
}
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn is_send_and_sync() {
|
||||
fn assert_bound<T: Send + Sync>() {}
|
||||
|
||||
assert_bound::<ReadHalf<RW>>();
|
||||
assert_bound::<WriteHalf<RW>>();
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn split_stream_id() {
|
||||
let (r1, w1) = split(RW);
|
||||
let (r2, w2) = split(RW);
|
||||
assert!(r1.is_pair_of(&w1));
|
||||
assert!(!r1.is_pair_of(&w2));
|
||||
assert!(r2.is_pair_of(&w2));
|
||||
assert!(!r2.is_pair_of(&w1));
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn unsplit_ok() {
|
||||
let (r, w) = split(RW);
|
||||
r.unsplit(w);
|
||||
}
|
||||
|
||||
#[test]
|
||||
#[should_panic]
|
||||
fn unsplit_err1() {
|
||||
let (r, _) = split(RW);
|
||||
let (_, w) = split(RW);
|
||||
r.unsplit(w);
|
||||
}
|
||||
|
||||
#[test]
|
||||
#[should_panic]
|
||||
fn unsplit_err2() {
|
||||
let (_, w) = split(RW);
|
||||
let (r, _) = split(RW);
|
||||
r.unsplit(w);
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue