Revision control

Copy as Markdown

Other Tools

use std::fmt::{self, Formatter};
use std::io::Cursor;
use serde::de;
use serde::Deserialize;
use rmp::Marker;
use rmp_serde::decode::{self, Error};
use rmp_serde::{Deserializer, Raw, RawRef};
#[test]
fn pass_nil() {
let buf = [0xc0];
let mut de = Deserializer::new(&buf[..]);
assert_eq!((), Deserialize::deserialize(&mut de).unwrap());
}
#[test]
fn fail_nil_from_reserved() {
let buf = [0xc1];
let mut de = Deserializer::new(&buf[..]);
let res: Result<(), Error> = Deserialize::deserialize(&mut de);
match res.err() {
Some(Error::TypeMismatch(Marker::Reserved)) => (),
other => panic!("unexpected result: {other:?}"),
}
}
#[test]
fn pass_bool() {
let buf = [0xc3, 0xc2];
let mut de = Deserializer::new(&buf[..]);
assert_eq!(true, Deserialize::deserialize(&mut de).unwrap());
assert_eq!(false, Deserialize::deserialize(&mut de).unwrap());
}
#[test]
fn fail_bool_from_fixint() {
let buf = [0x00];
let cur = Cursor::new(&buf[..]);
let mut deserializer = Deserializer::new(cur);
let res: Result<bool, Error> = Deserialize::deserialize(&mut deserializer);
match res.err().unwrap() {
Error::Syntax(..) => (),
other => panic!("unexpected result: {other:?}"),
}
}
#[test]
fn pass_u64() {
let buf = [0xcf, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff];
let cur = Cursor::new(&buf[..]);
let mut de = Deserializer::new(cur);
assert_eq!(18446744073709551615u64, Deserialize::deserialize(&mut de).unwrap());
}
#[test]
fn pass_u32() {
let buf = [0xce, 0xff, 0xff, 0xff, 0xff];
let cur = Cursor::new(&buf[..]);
let mut de = Deserializer::new(cur);
assert_eq!(4294967295u32, Deserialize::deserialize(&mut de).unwrap());
}
#[test]
fn fail_u32_from_u64() {
let buf = [0xcf, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff];
let cur = Cursor::new(&buf[..]);
let mut de = Deserializer::new(cur);
let res: Result<u32, Error> = Deserialize::deserialize(&mut de);
match res.err().unwrap() {
Error::Syntax(..) => (),
other => panic!("unexpected result: {other:?}"),
}
}
#[test]
fn pass_u16() {
let buf = [0xcd, 0xff, 0xff];
let cur = Cursor::new(&buf[..]);
let mut de = Deserializer::new(cur);
assert_eq!(65535u16, Deserialize::deserialize(&mut de).unwrap());
}
#[test]
fn pass_u8() {
let buf = [0xcc, 0xff];
let cur = Cursor::new(&buf[..]);
let mut de = Deserializer::new(cur);
assert_eq!(255u8, Deserialize::deserialize(&mut de).unwrap());
}
#[test]
fn pass_u8_from_64() {
let buf = [0xcf, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x2a];
let cur = Cursor::new(&buf[..]);
let mut de = Deserializer::new(cur);
assert_eq!(42u8, Deserialize::deserialize(&mut de).unwrap());
}
#[test]
fn pass_usize() {
let buf = [0xcc, 0xff];
let cur = Cursor::new(&buf[..]);
let mut de = Deserializer::new(cur);
assert_eq!(255usize, Deserialize::deserialize(&mut de).unwrap());
}
#[test]
fn pass_i64() {
let buf = [0xd3, 0x7f, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff];
let cur = Cursor::new(&buf[..]);
let mut de = Deserializer::new(cur);
assert_eq!(9223372036854775807i64, Deserialize::deserialize(&mut de).unwrap());
}
#[test]
fn pass_i32() {
let buf = [0xd2, 0x7f, 0xff, 0xff, 0xff];
let cur = Cursor::new(&buf[..]);
let mut de = Deserializer::new(cur);
assert_eq!(2147483647i32, Deserialize::deserialize(&mut de).unwrap());
}
#[test]
fn pass_i16() {
let buf = [0xd1, 0x7f, 0xff];
let cur = Cursor::new(&buf[..]);
let mut de = Deserializer::new(cur);
assert_eq!(32767i16, Deserialize::deserialize(&mut de).unwrap());
}
#[test]
fn pass_i8() {
let buf = [0xd0, 0x7f];
let cur = Cursor::new(&buf[..]);
let mut de = Deserializer::new(cur);
assert_eq!(127i8, Deserialize::deserialize(&mut de).unwrap());
}
#[test]
fn pass_isize() {
let buf = [0xd0, 0x7f];
let cur = Cursor::new(&buf[..]);
let mut de = Deserializer::new(cur);
assert_eq!(127isize, Deserialize::deserialize(&mut de).unwrap());
}
#[test]
fn pass_f32() {
let buf = [0xca, 0x7f, 0x7f, 0xff, 0xff];
let cur = Cursor::new(&buf[..]);
let mut de = Deserializer::new(cur);
assert_eq!(3.4028234e38_f32, Deserialize::deserialize(&mut de).unwrap());
}
#[test]
fn pass_f64() {
let buf = [0xcb, 0x40, 0x45, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00];
let cur = Cursor::new(&buf[..]);
let mut de = Deserializer::new(cur);
assert_eq!(42f64, Deserialize::deserialize(&mut de).unwrap());
}
// spot check tests for general integers -> float conversions
#[test]
fn pass_i8_as_f32() {
let buf = [0xd0, 0x7f];
let cur = Cursor::new(&buf[..]);
let mut de = Deserializer::new(cur);
assert_eq!(127f32, Deserialize::deserialize(&mut de).unwrap());
}
#[test]
fn pass_u32_as_f64() {
let buf = [0xce, 0xff, 0xff, 0xff, 0xff];
let cur = Cursor::new(&buf[..]);
let mut de = Deserializer::new(cur);
assert_eq!(4294967295f64, Deserialize::deserialize(&mut de).unwrap());
}
#[test]
fn pass_string() {
let buf = [0xaa, 0x6c, 0x65, 0x20, 0x6d, 0x65, 0x73, 0x73, 0x61, 0x67, 0x65];
let cur = Cursor::new(&buf[..]);
let mut de = Deserializer::new(cur);
let actual: String = Deserialize::deserialize(&mut de).unwrap();
assert_eq!("le message".to_string(), actual);
}
#[test]
fn pass_tuple() {
let buf = [0x92, 0x2a, 0xce, 0x0, 0x1, 0x88, 0x94];
let cur = Cursor::new(&buf[..]);
let mut de = Deserializer::new(cur);
let actual: (u32, u32) = Deserialize::deserialize(&mut de).unwrap();
assert_eq!((42, 100500), actual);
}
#[ignore]
#[test]
fn fail_tuple_len_mismatch() {
let buf = [0x92, 0x2a, 0xce, 0x0, 0x1, 0x88, 0x94];
let cur = Cursor::new(&buf[..]);
let mut de = Deserializer::new(cur);
let actual: Result<(u32,), Error> = Deserialize::deserialize(&mut de);
match actual.err().unwrap() {
Error::LengthMismatch(1) => (),
other => panic!("unexpected result: {other:?}"),
}
}
#[test]
fn pass_option_some() {
let buf = [0x1f];
let mut de = Deserializer::new(&buf[..]);
let actual: Option<u8> = Deserialize::deserialize(&mut de).unwrap();
assert_eq!(Some(31), actual);
}
#[test]
fn pass_option_none() {
let buf = [0xc0];
let mut de = Deserializer::new(&buf[..]);
let actual: Option<u8> = Deserialize::deserialize(&mut de).unwrap();
assert_eq!(None, actual);
}
#[test]
fn pass_nested_option_some() {
let buf = [0x1f];
let mut de = Deserializer::new(&buf[..]);
let actual: Option<Option<u8>> = Deserialize::deserialize(&mut de).unwrap();
assert_eq!(Some(Some(31)), actual);
}
#[test]
fn pass_nested_option_none() {
let buf = [0xc0];
let mut de = Deserializer::new(&buf[..]);
let actual: Option<Option<u8>> = Deserialize::deserialize(&mut de).unwrap();
assert_eq!(None, actual);
}
#[test]
fn fail_option_u8_from_reserved() {
let buf = [0xc1];
let cur = Cursor::new(&buf[..]);
let mut de = Deserializer::new(cur);
let actual: Result<Option<u8>, Error> = Deserialize::deserialize(&mut de);
match actual.err() {
Some(Error::TypeMismatch(Marker::Reserved)) => (),
other => panic!("unexpected result: {other:?}"),
}
}
#[test]
fn pass_vector() {
let buf = [0x92, 0x00, 0xcc, 0x80];
let cur = Cursor::new(&buf[..]);
let mut de = Deserializer::new(cur);
let actual: Vec<u8> = Deserialize::deserialize(&mut de).unwrap();
assert_eq!(vec![0, 128], actual);
}
#[test]
fn pass_map() {
use std::collections::HashMap;
let buf = [
0x82, // 2 (size)
0xa3, 0x69, 0x6e, 0x74, // 'int'
0xcc, 0x80, // 128
0xa3, 0x6b, 0x65, 0x79, // 'key'
0x2a, // 42
];
let cur = Cursor::new(&buf[..]);
let mut de = Deserializer::new(cur);
let actual = Deserialize::deserialize(&mut de).unwrap();
let mut expected = HashMap::new();
expected.insert("int".to_string(), 128);
expected.insert("key".to_string(), 42);
assert_eq!(expected, actual);
}
// TODO: Merge three of them.
#[test]
fn pass_bin8_into_bytebuf() {
use serde_bytes::ByteBuf;
let buf = [0xc4, 0x02, 0xcc, 0x80];
let cur = Cursor::new(&buf[..]);
let mut de = Deserializer::new(cur);
let actual: ByteBuf = Deserialize::deserialize(&mut de).unwrap();
assert_eq!([0xcc, 0x80], actual[..]);
}
#[test]
fn pass_bin16_into_bytebuf() {
use serde_bytes::ByteBuf;
let buf = [0xc5, 0x00, 0x02, 0xcc, 0x80];
let cur = Cursor::new(&buf[..]);
let mut de = Deserializer::new(cur);
let actual: ByteBuf = Deserialize::deserialize(&mut de).unwrap();
assert_eq!([0xcc, 0x80], actual[..]);
}
#[test]
fn pass_bin32_into_bytebuf() {
use serde_bytes::ByteBuf;
let buf = [0xc6, 0x00, 0x00, 0x00, 0x02, 0xcc, 0x80];
let cur = Cursor::new(&buf[..]);
let mut de = Deserializer::new(cur);
let actual: ByteBuf = Deserialize::deserialize(&mut de).unwrap();
assert_eq!([0xcc, 0x80], actual[..]);
}
#[test]
fn pass_bin8_into_bytebuf_regression_growing_buffer() {
use serde_bytes::ByteBuf;
// Try to deserialize large buf and a small buf
let buf = [0x92, 0xc4, 0x04, 0x71, 0x75, 0x75, 0x78, 0xc4, 0x03, 0x62, 0x61, 0x72];
let cur = Cursor::new(&buf[..]);
let mut de = Deserializer::new(cur);
let (large, small): (ByteBuf, ByteBuf) = Deserialize::deserialize(&mut de).unwrap();
let (large, small): (Vec<u8>, Vec<u8>) = (large.into_vec(), small.into_vec());
assert_eq!((b"quux".to_vec(), b"bar".to_vec()), (large, small));
}
#[test]
fn test_deserialize_numeric() {
#[derive(Debug, PartialEq)]
enum FloatOrInteger {
Float(f64),
Integer(u64),
}
impl<'de> de::Deserialize<'de> for FloatOrInteger {
fn deserialize<D>(de: D) -> Result<FloatOrInteger, D::Error>
where D: de::Deserializer<'de>
{
struct FloatOrIntegerVisitor;
impl<'de> de::Visitor<'de> for FloatOrIntegerVisitor {
type Value = FloatOrInteger;
fn expecting(&self, fmt: &mut Formatter<'_>) -> Result<(), fmt::Error> {
write!(fmt, "either a float or an integer")
}
fn visit_u64<E>(self, value: u64) -> Result<FloatOrInteger, E> {
Ok(FloatOrInteger::Integer(value))
}
fn visit_f64<E>(self, value: f64) -> Result<FloatOrInteger, E> {
Ok(FloatOrInteger::Float(value))
}
}
de.deserialize_any(FloatOrIntegerVisitor)
}
}
let buf = [203, 64, 36, 102, 102, 102, 102, 102, 102]; // 10.2
let mut de = Deserializer::new(&buf[..]);
let x: FloatOrInteger = Deserialize::deserialize(&mut de).unwrap();
assert_eq!(x, FloatOrInteger::Float(10.2));
let buf = [36]; // 36
let mut de = Deserializer::new(&buf[..]);
let x: FloatOrInteger = Deserialize::deserialize(&mut de).unwrap();
assert_eq!(x, FloatOrInteger::Integer(36));
}
#[test]
fn pass_deserializer_get_ref() {
let buf = [0xc0];
let cur = Cursor::new(&buf[..]);
let mut de = Deserializer::new(cur);
assert_eq!((), Deserialize::deserialize(&mut de).unwrap());
assert_eq!(1, de.get_ref().position());
}
#[test]
fn pass_deserializer_get_mut() {
let buf = [0xc0];
let cur = Cursor::new(&buf[..]);
let mut de = Deserializer::new(cur);
assert_eq!((), Deserialize::deserialize(&mut de).unwrap());
de.get_mut().set_position(0);
assert_eq!((), Deserialize::deserialize(&mut de).unwrap());
}
#[test]
fn pass_deserializer_into_inner() {
let buf = [0xc0];
let cur = Cursor::new(&buf[..]);
let mut de = Deserializer::new(cur);
assert_eq!((), Deserialize::deserialize(&mut de).unwrap());
let cur = de.into_inner();
assert_eq!(1, cur.position());
}
#[test]
fn pass_deserializer_cursor_position() {
let mut de = Deserializer::new(Cursor::new(vec![0xce, 0xff, 0xff, 0xff, 0xff]));
assert_eq!(4294967295u32, Deserialize::deserialize(&mut de).unwrap());
assert_eq!(5, de.position());
}
#[test]
fn pass_from() {
assert_eq!(2147483647, decode::from_read(&[0xd2, 0x7f, 0xff, 0xff, 0xff][..]).unwrap());
}
#[test]
fn pass_raw_valid_utf8() {
let buf = vec![0xa3, 0x6b, 0x65, 0x79];
let raw: Raw = rmp_serde::from_slice(&buf[..]).unwrap();
assert!(raw.is_str());
assert_eq!("key", raw.as_str().unwrap());
assert_eq!([0x6b, 0x65, 0x79], raw.as_bytes());
}
#[test]
fn pass_raw_invalid_utf8() {
// >>> msgpack.dumps(msgpack.dumps([200, []]))
// '\xa4\x92\xcc\xc8\x90'
let buf = vec![0xa4, 0x92, 0xcc, 0xc8, 0x90];
let raw: Raw = rmp_serde::from_slice(&buf[..]).unwrap();
assert!(raw.is_err());
assert_eq!(0, raw.as_err().unwrap().valid_up_to());
assert_eq!([0x92, 0xcc, 0xc8, 0x90], raw.as_bytes());
}
#[test]
fn pass_raw_ref_valid_utf8() {
let buf = vec![0xa3, 0x6b, 0x65, 0x79];
let raw: RawRef<'_> = rmp_serde::from_slice(&buf[..]).unwrap();
assert!(raw.is_str());
assert_eq!("key", raw.as_str().unwrap());
assert_eq!([0x6b, 0x65, 0x79], raw.as_bytes());
}
#[test]
fn pass_raw_ref_invalid_utf8() {
// >>> msgpack.dumps(msgpack.dumps([200, []]))
// '\xa4\x92\xcc\xc8\x90'
let buf = vec![0xa4, 0x92, 0xcc, 0xc8, 0x90];
let raw: RawRef<'_> = rmp_serde::from_slice(&buf[..]).unwrap();
assert!(raw.is_err());
assert_eq!(0, raw.as_err().unwrap().valid_up_to());
assert_eq!([0x92, 0xcc, 0xc8, 0x90], raw.as_bytes());
}
#[test]
fn fail_str_invalid_utf8() {
let buf = vec![0xa4, 0x92, 0xcc, 0xc8, 0x90];
let err: Result<String, decode::Error> = rmp_serde::from_slice(&buf[..]);
assert!(err.is_err());
match err.err().unwrap() {
decode::Error::Utf8Error(err) => assert_eq!(0, err.valid_up_to()),
// decode::Error::Syntax(err) => {}
err => panic!("unexpected error: {:?}", err),
}
}
#[test]
fn fail_depth_limit() {
#[allow(dead_code)]
struct Nested {
sub: Vec<Nested>,
}
impl<'de> de::Deserialize<'de> for Nested {
fn deserialize<D>(de: D) -> Result<Self, D::Error>
where D: de::Deserializer<'de>
{
let nested = Vec::deserialize(de)?;
Ok(Nested { sub: nested })
}
}
let mut data = Vec::new();
for _ in 0..100 {
data.push(0x91u8);
}
let mut reader = rmp_serde::Deserializer::new(Cursor::new(data));
reader.set_max_depth(100);
let res = Nested::deserialize(&mut reader);
match res.err().unwrap() {
decode::Error::DepthLimitExceeded => (),
other => panic!("unexpected result: {other:?}"),
}
}