Tuple: add tests for deserialization from sequence

(review this commit with "ignore whitespace changes" option on)
This commit is contained in:
Mingun
2024-08-16 22:18:20 +05:00
parent a94d8750fb
commit c383e4f953
@@ -437,11 +437,14 @@ fn newtype_with_newtype() {
); );
} }
#[test] mod tuple {
fn tuple() { use super::*;
#[test]
fn map() {
let value = AdjacentlyTagged::Tuple::<u8>(1, 1); let value = AdjacentlyTagged::Tuple::<u8>(1, 1);
// tuple with tag first // Map: tag + content
assert_tokens( assert_tokens(
&value, &value,
&[ &[
@@ -463,7 +466,7 @@ fn tuple() {
], ],
); );
// tuple with content first // Map: content + tag
assert_de_tokens( assert_de_tokens(
&value, &value,
&[ &[
@@ -484,6 +487,29 @@ fn tuple() {
Token::StructEnd, Token::StructEnd,
], ],
); );
}
#[test]
fn seq() {
let value = AdjacentlyTagged::Tuple::<u8>(1, 1);
// Seq: tag + content
assert_de_tokens(
&value,
&[
Token::Seq { len: Some(2) },
Token::UnitVariant {
name: "AdjacentlyTagged",
variant: "Tuple",
},
Token::Tuple { len: 2 },
Token::U8(1),
Token::U8(1),
Token::TupleEnd,
Token::SeqEnd,
],
);
}
} }
#[test] #[test]