bincode-next 3.1.1

A compact, ultra-fast binary serialization format for Rust, optimized for networking and storage!
Documentation
#![cfg(feature = "async-fiber")]
mod proptests {
    use bincode_next::Decode;
    use bincode_next::Encode;
    use bincode_next::config;
    use bincode_next::decode_async;
    use bincode_next::encode_to_vec;
    use futures_io::AsyncRead;
    use proptest::prelude::*;
    use std::pin::Pin;
    use std::task::Context;
    use std::task::Poll;

    #[derive(Encode, Decode, PartialEq, Debug, Clone)]
    struct TestData {
        a: u64,
        b: String,
        c: Vec<u8>,
    }

    struct RandomChunkReader {
        data: Vec<u8>,
        chunk_sizes: Vec<usize>,
        chunk_idx: usize,
        pos: usize,
    }

    impl AsyncRead for RandomChunkReader {
        fn poll_read(
            mut self: Pin<&mut Self>,
            _cx: &mut Context<'_>,
            buf: &mut [u8],
        ) -> Poll<std::io::Result<usize>> {
            if self.pos >= self.data.len() || buf.is_empty() {
                return Poll::Ready(Ok(0));
            }
            let chunk_size = *self.chunk_sizes.get(self.chunk_idx).unwrap_or(&1);
            self.chunk_idx += 1;
            let to_read = std::cmp::min(chunk_size, buf.len());
            let end = std::cmp::min(self.pos + to_read, self.data.len());
            let copied = end - self.pos;
            buf[..copied].copy_from_slice(&self.data[self.pos..end]);
            self.pos = end;
            Poll::Ready(Ok(copied))
        }
    }

    proptest! {
        #[test]
        #[cfg_attr(miri, ignore)]
        fn test_async_fiber_decode_random_chunks(
            chunk_sizes in prop::collection::vec(1..50usize, 100),
            a in any::<u64>(),
            b in ".*",
            c in prop::collection::vec(any::<u8>(), 0..100),
        ) {
            let rt = tokio::runtime::Builder::new_current_thread().build().unwrap();
            let original = TestData { a, b, c };
            let encoded = encode_to_vec(&original, config::standard()).unwrap();

            rt.block_on(async {
                let reader = RandomChunkReader {
                    data: encoded,
                    chunk_sizes,
                    chunk_idx: 0,
                    pos: 0,
                };
                let decoded: TestData = decode_async::<TestData, _, _>(config::standard(), reader).await.unwrap();
                prop_assert_eq!(original, decoded);
                Ok(())
            }).unwrap();
        }
    }
}