diff options
author | Sam Scott <sam.scott89@gmail.com> | 2019-01-23 11:13:18 -0500 |
---|---|---|
committer | Sam Scott <sam.scott89@gmail.com> | 2019-01-23 11:13:18 -0500 |
commit | b69c42eb9b9f055e74353c9c149074616eff181f (patch) | |
tree | 2cf99efcf18ae20feed9fd843771e96be0bd3b9d /tests | |
parent | 6689581cfa2b9eacd6ec5d6402cb920fecf1eb63 (diff) |
Add documentation and workaroud for `#[serde(flatten)]` usage.
Diffstat (limited to 'tests')
-rw-r--r-- | tests/test_deserialize.rs | 59 | ||||
-rw-r--r-- | tests/test_serialize.rs | 21 |
2 files changed, 80 insertions, 0 deletions
diff --git a/tests/test_deserialize.rs b/tests/test_deserialize.rs index 946a8f3..81dc954 100644 --- a/tests/test_deserialize.rs +++ b/tests/test_deserialize.rs @@ -1,3 +1,4 @@ +extern crate serde; #[macro_use] extern crate serde_derive; extern crate serde_qs as qs; @@ -479,3 +480,61 @@ fn strict_mode() { fn square_brackets_in_values() { map_test!("foo=%5BHello%5D", "foo"["[Hello]"]); } + +#[test] +#[ignore] +fn deserialize_flatten() { + #[derive(Deserialize,Serialize,Debug, PartialEq)] + struct Query { + a: u8, + #[serde(flatten)] + common: CommonParams, + } + + #[derive(Deserialize,Serialize,Debug, PartialEq)] + struct CommonParams { + limit: u64, + offset: u64, + remaining: bool, + } + + let params = "a=1&limit=100&offset=50&remaining=true"; + let query = Query { a: 1, common: CommonParams { limit: 100, offset: 50, remaining: true } }; + let rec_query: Result<Query, _> = qs::from_str(params); + assert_eq!(rec_query.unwrap(), query); +} + +#[test] +fn deserialize_flatten_workaround() { + #[derive(Deserialize,Serialize,Debug, PartialEq)] + struct Query { + a: u8, + #[serde(flatten)] + common: CommonParams, + } + + #[derive(Deserialize,Serialize,Debug, PartialEq)] + struct CommonParams { + #[serde(deserialize_with="from_str")] + limit: u64, + #[serde(deserialize_with="from_str")] + offset: u64, + #[serde(deserialize_with="from_str")] + remaining: bool, + } + + let params = "a=1&limit=100&offset=50&remaining=true"; + let query = Query { a: 1, common: CommonParams { limit: 100, offset: 50, remaining: true } }; + let rec_query: Result<Query, _> = qs::from_str(params); + assert_eq!(rec_query.unwrap(), query); +} + +use serde::de::Error; + +fn from_str<'de, D, S>(deserializer: D) -> Result<S, D::Error> + where D: serde::Deserializer<'de>, + S: std::str::FromStr +{ + let s = <&str as serde::Deserialize>::deserialize(deserializer)?; + S::from_str(&s).map_err(|_| D::Error::custom("could not parse string")) +}
\ No newline at end of file diff --git a/tests/test_serialize.rs b/tests/test_serialize.rs index 80e2d7c..5a918ab 100644 --- a/tests/test_serialize.rs +++ b/tests/test_serialize.rs @@ -92,3 +92,24 @@ fn serialize_enum() { let rec_params = qs::to_string(&query).unwrap(); assert_eq!(rec_params, params); } + +#[test] +fn serialize_flatten() { + #[derive(Deserialize,Serialize,Debug, PartialEq)] + struct Query { + a: u8, + #[serde(flatten)] + common: CommonParams, + } + + #[derive(Deserialize,Serialize,Debug, PartialEq)] + struct CommonParams { + limit: u64, + offset: u64, + } + + let params = "a=1&limit=100&offset=50"; + let query = Query { a: 1, common: CommonParams { limit: 100, offset: 50 } }; + let rec_params = qs::to_string(&query).unwrap(); + assert_eq!(rec_params, params); +} |