diff options
author | Rudi Floren <rudi.floren@gmail.com> | 2023-03-02 06:01:26 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-03-01 23:01:26 -0600 |
commit | 096d851f6d878c2c727f530ccc5749b4d8be2ab0 (patch) | |
tree | 15b73f2eb25790ebfaa0c43f998246a5b4267ccb /tests/test_deserialize.rs | |
parent | 849cca77d541915552aa44e8cfdbbf90d2ff2042 (diff) |
Improve support unit types (#76)
* fix unit type serialization issue
`()` and `A` returned a no key error previously. This is very
unergonimic if you just have a trait bound for Serialize and want to
generate an empty querystring `?`
* add support for deserializing unit structs
* Comment updates for serializer methods
Diffstat (limited to 'tests/test_deserialize.rs')
-rw-r--r-- | tests/test_deserialize.rs | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/tests/test_deserialize.rs b/tests/test_deserialize.rs index 92e5f53..b2f9dc8 100644 --- a/tests/test_deserialize.rs +++ b/tests/test_deserialize.rs @@ -699,3 +699,26 @@ fn deserialize_map_with_int_keys() { serde_qs::from_str::<Mapping>("mapping[1]=2&mapping[1]=4") .expect_err("should error with repeated key"); } + +#[test] +fn deserialize_unit_types() { + #[derive(Debug, Deserialize, PartialEq)] + struct A; + #[derive(Debug, Deserialize, PartialEq)] + struct B<'a> { + t: (), + a: &'a str, + } + + let test: () = serde_qs::from_str("").unwrap(); + assert_eq!(test, ()); + + let test: A = serde_qs::from_str("").unwrap(); + assert_eq!(test, A); + + let test: B = serde_qs::from_str("a=test&t=").unwrap(); + assert_eq!(test, B { t: (), a: "test" }); + + let test: B = serde_qs::from_str("t=&a=test").unwrap(); + assert_eq!(test, B { t: (), a: "test" }); +} |