From e07b62d74a451a0ba6617f1bc7875d9c71c85ee2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jakub=20=C5=81abor?= Date: Sun, 2 Oct 2022 21:50:51 +0200 Subject: fix(serde_v8): Implement MapAccess for StructAccess (#15962) `StructAccess` implements` serde::de::SeqAccess` instead of `serde::de::MapAccess` thus interpreting structs as sequences. --- serde_v8/tests/de.rs | 59 +++++++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 58 insertions(+), 1 deletion(-) (limited to 'serde_v8/tests') diff --git a/serde_v8/tests/de.rs b/serde_v8/tests/de.rs index c29b35760..7affe5f8e 100644 --- a/serde_v8/tests/de.rs +++ b/serde_v8/tests/de.rs @@ -1,5 +1,5 @@ // Copyright 2018-2022 the Deno authors. All rights reserved. MIT license. -use serde::Deserialize; +use serde::{Deserialize, Deserializer}; use serde_v8::utils::{js_exec, v8_do}; use serde_v8::ByteString; @@ -233,6 +233,63 @@ fn de_buffers() { ); } +// Structs +#[derive(Debug, PartialEq, Deserialize)] +struct StructUnit; + +#[derive(Debug, PartialEq)] +struct StructPayload { + a: u64, + b: u64, +} + +struct StructVisitor; + +impl<'de> serde::de::Visitor<'de> for StructVisitor { + type Value = StructPayload; + fn expecting(&self, formatter: &mut std::fmt::Formatter) -> std::fmt::Result { + formatter.write_str("struct StructPayload") + } + fn visit_map(self, mut map: A) -> Result + where + A: serde::de::MapAccess<'de>, + { + let mut payload = StructPayload { a: 0, b: 0 }; + while let Some(key) = map.next_key::()? { + match key.as_ref() { + "a" => payload.a = map.next_value()?, + "b" => payload.b = map.next_value()?, + f => panic!("Unknown field {}", f), + } + } + Ok(payload) + } +} + +detest!(de_unit_struct, StructUnit, "'StructUnit'", StructUnit); + +#[test] +fn de_struct() { + dedo("({ a: 1, b: 2 })", |scope, v| { + let mut de = serde_v8::Deserializer::new(scope, v, None); + let payload = de + .deserialize_struct("StructPayload", &[], StructVisitor) + .unwrap(); + assert_eq!(payload, StructPayload { a: 1, b: 2 }) + }) +} + +#[test] +fn de_struct_hint() { + dedo("({ a: 1, b: 2 })", |scope, v| { + let mut de = serde_v8::Deserializer::new(scope, v, None); + let payload = de + .deserialize_struct("StructPayload", &["a", "b"], StructVisitor) + .unwrap(); + assert_eq!(payload, StructPayload { a: 1, b: 2 }) + }) +} + //// // JSON tests: serde_json::Value compatibility //// -- cgit v1.2.3