diff options
author | Sam Scott <sam@osohq.com> | 2021-06-09 15:32:07 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-06-09 15:32:07 -0400 |
commit | e369232e36d6fda5df3d2e533b2cdc5c5d2a23bb (patch) | |
tree | c04efbee5807cca63c99d96dbba8645f5b96bc99 /tests/test_deserialize.rs | |
parent | 5bfaa7aa9f38806436e15928917cbd841a61e0f2 (diff) |
Support deserializing sequences to a hashmap with keys. (#51)
Diffstat (limited to 'tests/test_deserialize.rs')
-rw-r--r-- | tests/test_deserialize.rs | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/tests/test_deserialize.rs b/tests/test_deserialize.rs index a620828..097cc57 100644 --- a/tests/test_deserialize.rs +++ b/tests/test_deserialize.rs @@ -656,3 +656,20 @@ fn deserialize_map_with_unit_enum_keys() { assert_eq!(test.point[&Operator::Gt], 123); assert_eq!(test.point[&Operator::Lt], 321); } + +#[test] +fn deserialize_map_with_int_keys() { + #[derive(Debug, Deserialize)] + struct Mapping { + mapping: HashMap<u64, u64>, + } + + let test: Mapping = serde_qs::from_str("mapping[1]=2&mapping[3]=4").unwrap(); + + assert_eq!(test.mapping.get(&1).cloned(), Some(2)); + assert_eq!(test.mapping.get(&3).cloned(), Some(4)); + assert_eq!(test.mapping.get(&2).cloned(), None); + + serde_qs::from_str::<Mapping>("mapping[1]=2&mapping[1]=4") + .expect_err("should error with repeated key"); +} |