feat(body): replace Chunk type with Bytes
Closes #1931 BREAKING CHANGE: All usage of `hyper::Chunk` should be replaced with `bytes::Bytes` (or `hyper::body::Bytes`).
This commit is contained in:
@@ -12,7 +12,6 @@ use super::{/*Decode,*/ Decoder, Encode, EncodedBuf, Encoder, Http1Transaction,
|
||||
use crate::common::{task, Pin, Poll, Unpin};
|
||||
use crate::headers::connection_keep_alive;
|
||||
use crate::proto::{BodyLength, DecodedLength, MessageHead};
|
||||
use crate::Chunk;
|
||||
|
||||
const H2_PREFACE: &'static [u8] = b"PRI * HTTP/2.0\r\n\r\nSM\r\n\r\n";
|
||||
|
||||
@@ -205,7 +204,7 @@ where
|
||||
pub fn poll_read_body(
|
||||
&mut self,
|
||||
cx: &mut task::Context<'_>,
|
||||
) -> Poll<Option<io::Result<Chunk>>> {
|
||||
) -> Poll<Option<io::Result<Bytes>>> {
|
||||
debug_assert!(self.can_read_body());
|
||||
|
||||
let (reading, ret) = match self.state.reading {
|
||||
@@ -217,7 +216,7 @@ where
|
||||
(
|
||||
Reading::KeepAlive,
|
||||
if !slice.is_empty() {
|
||||
Some(Ok(Chunk::from(slice)))
|
||||
Some(Ok(slice))
|
||||
} else {
|
||||
None
|
||||
},
|
||||
@@ -229,7 +228,7 @@ where
|
||||
// an empty slice...
|
||||
(Reading::Closed, None)
|
||||
} else {
|
||||
return Poll::Ready(Some(Ok(Chunk::from(slice))));
|
||||
return Poll::Ready(Some(Ok(slice)));
|
||||
};
|
||||
(reading, Poll::Ready(chunk))
|
||||
}
|
||||
@@ -930,7 +929,7 @@ mod tests {
|
||||
|
||||
// an empty IO, we'll be skipping and using the read buffer anyways
|
||||
let io = tokio_test::io::Builder::new().build();
|
||||
let mut conn = Conn::<_, crate::Chunk, crate::proto::h1::ServerTransaction>::new(io);
|
||||
let mut conn = Conn::<_, bytes::Bytes, crate::proto::h1::ServerTransaction>::new(io);
|
||||
*conn.io.read_buf_mut() = ::bytes::BytesMut::from(&s[..]);
|
||||
conn.state.cached_headers = Some(HeaderMap::with_capacity(2));
|
||||
|
||||
@@ -981,7 +980,7 @@ mod tests {
|
||||
let good_message = b"GET / HTTP/1.1\r\n\r\n".to_vec();
|
||||
let len = good_message.len();
|
||||
let io = AsyncIo::new_buf(good_message, len);
|
||||
let mut conn = Conn::<_, proto::Chunk, ServerTransaction>::new(io);
|
||||
let mut conn = Conn::<_, proto::Bytes, ServerTransaction>::new(io);
|
||||
|
||||
match conn.poll().unwrap() {
|
||||
Async::Ready(Some(Frame::Message { message, body: false })) => {
|
||||
@@ -999,7 +998,7 @@ mod tests {
|
||||
let _: Result<(), ()> = future::lazy(|| {
|
||||
let good_message = b"GET / HTTP/1.1\r\nHost: foo.bar\r\n\r\n".to_vec();
|
||||
let io = AsyncIo::new_buf(good_message, 10);
|
||||
let mut conn = Conn::<_, proto::Chunk, ServerTransaction>::new(io);
|
||||
let mut conn = Conn::<_, proto::Bytes, ServerTransaction>::new(io);
|
||||
assert!(conn.poll().unwrap().is_not_ready());
|
||||
conn.io.io_mut().block_in(50);
|
||||
let async = conn.poll().unwrap();
|
||||
@@ -1015,7 +1014,7 @@ mod tests {
|
||||
#[test]
|
||||
fn test_conn_init_read_eof_idle() {
|
||||
let io = AsyncIo::new_buf(vec![], 1);
|
||||
let mut conn = Conn::<_, proto::Chunk, ServerTransaction>::new(io);
|
||||
let mut conn = Conn::<_, proto::Bytes, ServerTransaction>::new(io);
|
||||
conn.state.idle();
|
||||
|
||||
match conn.poll().unwrap() {
|
||||
@@ -1027,7 +1026,7 @@ mod tests {
|
||||
#[test]
|
||||
fn test_conn_init_read_eof_idle_partial_parse() {
|
||||
let io = AsyncIo::new_buf(b"GET / HTTP/1.1".to_vec(), 100);
|
||||
let mut conn = Conn::<_, proto::Chunk, ServerTransaction>::new(io);
|
||||
let mut conn = Conn::<_, proto::Bytes, ServerTransaction>::new(io);
|
||||
conn.state.idle();
|
||||
|
||||
match conn.poll() {
|
||||
@@ -1041,7 +1040,7 @@ mod tests {
|
||||
let _: Result<(), ()> = future::lazy(|| {
|
||||
// server ignores
|
||||
let io = AsyncIo::new_eof();
|
||||
let mut conn = Conn::<_, proto::Chunk, ServerTransaction>::new(io);
|
||||
let mut conn = Conn::<_, proto::Bytes, ServerTransaction>::new(io);
|
||||
conn.state.busy();
|
||||
|
||||
match conn.poll().unwrap() {
|
||||
@@ -1051,7 +1050,7 @@ mod tests {
|
||||
|
||||
// client
|
||||
let io = AsyncIo::new_eof();
|
||||
let mut conn = Conn::<_, proto::Chunk, ClientTransaction>::new(io);
|
||||
let mut conn = Conn::<_, proto::Bytes, ClientTransaction>::new(io);
|
||||
conn.state.busy();
|
||||
|
||||
match conn.poll() {
|
||||
@@ -1066,7 +1065,7 @@ mod tests {
|
||||
fn test_conn_body_finish_read_eof() {
|
||||
let _: Result<(), ()> = future::lazy(|| {
|
||||
let io = AsyncIo::new_eof();
|
||||
let mut conn = Conn::<_, proto::Chunk, ClientTransaction>::new(io);
|
||||
let mut conn = Conn::<_, proto::Bytes, ClientTransaction>::new(io);
|
||||
conn.state.busy();
|
||||
conn.state.writing = Writing::KeepAlive;
|
||||
conn.state.reading = Reading::Body(Decoder::length(0));
|
||||
@@ -1091,7 +1090,7 @@ mod tests {
|
||||
fn test_conn_message_empty_body_read_eof() {
|
||||
let _: Result<(), ()> = future::lazy(|| {
|
||||
let io = AsyncIo::new_buf(b"HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n".to_vec(), 1024);
|
||||
let mut conn = Conn::<_, proto::Chunk, ClientTransaction>::new(io);
|
||||
let mut conn = Conn::<_, proto::Bytes, ClientTransaction>::new(io);
|
||||
conn.state.busy();
|
||||
conn.state.writing = Writing::KeepAlive;
|
||||
|
||||
@@ -1115,7 +1114,7 @@ mod tests {
|
||||
fn test_conn_read_body_end() {
|
||||
let _: Result<(), ()> = future::lazy(|| {
|
||||
let io = AsyncIo::new_buf(b"POST / HTTP/1.1\r\nContent-Length: 5\r\n\r\n12345".to_vec(), 1024);
|
||||
let mut conn = Conn::<_, proto::Chunk, ServerTransaction>::new(io);
|
||||
let mut conn = Conn::<_, proto::Bytes, ServerTransaction>::new(io);
|
||||
conn.state.busy();
|
||||
|
||||
match conn.poll() {
|
||||
@@ -1145,7 +1144,7 @@ mod tests {
|
||||
#[test]
|
||||
fn test_conn_closed_read() {
|
||||
let io = AsyncIo::new_buf(vec![], 0);
|
||||
let mut conn = Conn::<_, proto::Chunk, ServerTransaction>::new(io);
|
||||
let mut conn = Conn::<_, proto::Bytes, ServerTransaction>::new(io);
|
||||
conn.state.close();
|
||||
|
||||
match conn.poll().unwrap() {
|
||||
@@ -1159,7 +1158,7 @@ mod tests {
|
||||
let _ = pretty_env_logger::try_init();
|
||||
let _: Result<(), ()> = future::lazy(|| {
|
||||
let io = AsyncIo::new_buf(vec![], 0);
|
||||
let mut conn = Conn::<_, proto::Chunk, ServerTransaction>::new(io);
|
||||
let mut conn = Conn::<_, proto::Bytes, ServerTransaction>::new(io);
|
||||
let max = super::super::io::DEFAULT_MAX_BUFFER_SIZE + 4096;
|
||||
conn.state.writing = Writing::Body(Encoder::length((max * 2) as u64));
|
||||
|
||||
@@ -1184,7 +1183,7 @@ mod tests {
|
||||
fn test_conn_body_write_chunked() {
|
||||
let _: Result<(), ()> = future::lazy(|| {
|
||||
let io = AsyncIo::new_buf(vec![], 4096);
|
||||
let mut conn = Conn::<_, proto::Chunk, ServerTransaction>::new(io);
|
||||
let mut conn = Conn::<_, proto::Bytes, ServerTransaction>::new(io);
|
||||
conn.state.writing = Writing::Body(Encoder::chunked());
|
||||
|
||||
assert!(conn.start_send(Frame::Body { chunk: Some("headers".into()) }).unwrap().is_ready());
|
||||
@@ -1197,7 +1196,7 @@ mod tests {
|
||||
fn test_conn_body_flush() {
|
||||
let _: Result<(), ()> = future::lazy(|| {
|
||||
let io = AsyncIo::new_buf(vec![], 1024 * 1024 * 5);
|
||||
let mut conn = Conn::<_, proto::Chunk, ServerTransaction>::new(io);
|
||||
let mut conn = Conn::<_, proto::Bytes, ServerTransaction>::new(io);
|
||||
conn.state.writing = Writing::Body(Encoder::length(1024 * 1024));
|
||||
assert!(conn.start_send(Frame::Body { chunk: Some(vec![b'a'; 1024 * 1024].into()) }).unwrap().is_ready());
|
||||
assert!(!conn.can_buffer_body());
|
||||
@@ -1234,7 +1233,7 @@ mod tests {
|
||||
// test that once writing is done, unparks
|
||||
let f = future::lazy(|| {
|
||||
let io = AsyncIo::new_buf(vec![], 4096);
|
||||
let mut conn = Conn::<_, proto::Chunk, ServerTransaction>::new(io);
|
||||
let mut conn = Conn::<_, proto::Bytes, ServerTransaction>::new(io);
|
||||
conn.state.reading = Reading::KeepAlive;
|
||||
assert!(conn.poll().unwrap().is_not_ready());
|
||||
|
||||
@@ -1248,7 +1247,7 @@ mod tests {
|
||||
// test that flushing when not waiting on read doesn't unpark
|
||||
let f = future::lazy(|| {
|
||||
let io = AsyncIo::new_buf(vec![], 4096);
|
||||
let mut conn = Conn::<_, proto::Chunk, ServerTransaction>::new(io);
|
||||
let mut conn = Conn::<_, proto::Bytes, ServerTransaction>::new(io);
|
||||
conn.state.writing = Writing::KeepAlive;
|
||||
assert!(conn.poll_complete().unwrap().is_ready());
|
||||
Ok::<(), ()>(())
|
||||
@@ -1259,7 +1258,7 @@ mod tests {
|
||||
// test that flushing and writing isn't done doesn't unpark
|
||||
let f = future::lazy(|| {
|
||||
let io = AsyncIo::new_buf(vec![], 4096);
|
||||
let mut conn = Conn::<_, proto::Chunk, ServerTransaction>::new(io);
|
||||
let mut conn = Conn::<_, proto::Bytes, ServerTransaction>::new(io);
|
||||
conn.state.reading = Reading::KeepAlive;
|
||||
assert!(conn.poll().unwrap().is_not_ready());
|
||||
conn.state.writing = Writing::Body(Encoder::length(5_000));
|
||||
@@ -1272,7 +1271,7 @@ mod tests {
|
||||
#[test]
|
||||
fn test_conn_closed_write() {
|
||||
let io = AsyncIo::new_buf(vec![], 0);
|
||||
let mut conn = Conn::<_, proto::Chunk, ServerTransaction>::new(io);
|
||||
let mut conn = Conn::<_, proto::Bytes, ServerTransaction>::new(io);
|
||||
conn.state.close();
|
||||
|
||||
match conn.start_send(Frame::Body { chunk: Some(b"foobar".to_vec().into()) }) {
|
||||
@@ -1286,7 +1285,7 @@ mod tests {
|
||||
#[test]
|
||||
fn test_conn_write_empty_chunk() {
|
||||
let io = AsyncIo::new_buf(vec![], 0);
|
||||
let mut conn = Conn::<_, proto::Chunk, ServerTransaction>::new(io);
|
||||
let mut conn = Conn::<_, proto::Bytes, ServerTransaction>::new(io);
|
||||
conn.state.writing = Writing::KeepAlive;
|
||||
|
||||
assert!(conn.start_send(Frame::Body { chunk: None }).unwrap().is_ready());
|
||||
|
||||
@@ -646,7 +646,7 @@ mod tests {
|
||||
// the request is ready to write later...
|
||||
//let io = AsyncIo::new_buf(b"HTTP/1.1 200 OK\r\n\r\n".to_vec(), 0);
|
||||
let (mut tx, rx) = crate::client::dispatch::channel();
|
||||
let conn = Conn::<_, crate::Chunk, ClientTransaction>::new(io);
|
||||
let conn = Conn::<_, bytes::Bytes, ClientTransaction>::new(io);
|
||||
let mut dispatcher = Dispatcher::new(Client::new(rx), conn);
|
||||
|
||||
// First poll is needed to allow tx to send...
|
||||
@@ -681,7 +681,7 @@ mod tests {
|
||||
.build();
|
||||
|
||||
let (mut tx, rx) = crate::client::dispatch::channel();
|
||||
let conn = Conn::<_, crate::Chunk, ClientTransaction>::new(io);
|
||||
let conn = Conn::<_, bytes::Bytes, ClientTransaction>::new(io);
|
||||
let mut dispatcher = tokio_test::task::spawn(Dispatcher::new(Client::new(rx), conn));
|
||||
|
||||
// First poll is needed to allow tx to send...
|
||||
|
||||
@@ -962,10 +962,10 @@ mod tests {
|
||||
let s = "Hello, World!";
|
||||
b.bytes = s.len() as u64;
|
||||
|
||||
let mut write_buf = WriteBuf::<crate::Chunk>::new();
|
||||
let mut write_buf = WriteBuf::<bytes::Bytes>::new();
|
||||
write_buf.set_strategy(WriteStrategy::Flatten);
|
||||
b.iter(|| {
|
||||
let chunk = crate::Chunk::from(s);
|
||||
let chunk = bytes::Bytes::from(s);
|
||||
write_buf.buffer(chunk);
|
||||
::test::black_box(&write_buf);
|
||||
write_buf.headers.bytes.clear();
|
||||
|
||||
Reference in New Issue
Block a user