diff options
| author | Jakub Łabor <jacob.labor@gmail.com> | 2022-10-02 21:50:51 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2022-10-02 21:50:51 +0200 |
| commit | e07b62d74a451a0ba6617f1bc7875d9c71c85ee2 (patch) | |
| tree | 03f3ac54aebcf2a4693f80043da4a21a74d0e531 /serde_v8/tests | |
| parent | a55b194638bcaace38917703b7d9233fb1989d44 (diff) | |
fix(serde_v8): Implement MapAccess for StructAccess (#15962)
`StructAccess` implements` serde::de::SeqAccess` instead of
`serde::de::MapAccess` thus interpreting structs as sequences.
Diffstat (limited to 'serde_v8/tests')
| -rw-r--r-- | serde_v8/tests/de.rs | 59 |
1 files changed, 58 insertions, 1 deletions
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<A>(self, mut map: A) -> Result<Self::Value, A::Error> + where + A: serde::de::MapAccess<'de>, + { + let mut payload = StructPayload { a: 0, b: 0 }; + while let Some(key) = map.next_key::<String>()? { + 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 //// |
