summaryrefslogtreecommitdiff
path: root/tests/test_deserialize.rs
diff options
context:
space:
mode:
authorRudi Floren <rudi.floren@gmail.com>2023-03-02 06:01:26 +0100
committerGitHub <noreply@github.com>2023-03-01 23:01:26 -0600
commit096d851f6d878c2c727f530ccc5749b4d8be2ab0 (patch)
tree15b73f2eb25790ebfaa0c43f998246a5b4267ccb /tests/test_deserialize.rs
parent849cca77d541915552aa44e8cfdbbf90d2ff2042 (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.rs23
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" });
+}