From 8cc731bfb6e0d6a9f7e386993d52c66030b84359 Mon Sep 17 00:00:00 2001 From: fx_kirin Date: Mon, 1 Jun 2020 15:08:25 +0900 Subject: [PATCH 1/2] fixing option handling. --- src/datetime.rs | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/datetime.rs b/src/datetime.rs index 643d34402d..e56ec6a75d 100644 --- a/src/datetime.rs +++ b/src/datetime.rs @@ -1184,7 +1184,7 @@ pub mod serde { where S: ser::Serializer { match *opt { - Some(ref dt) => ts_nanoseconds::serialize(dt, serializer), + Some(ref dt) => serializer.serialize_some(&dt.timestamp_nanos()), None => serializer.serialize_none(), } } @@ -1475,7 +1475,7 @@ pub mod serde { where S: ser::Serializer { match *opt { - Some(ref dt) => ts_milliseconds::serialize(dt, serializer), + Some(ref dt) => serializer.serialize_some(&dt.timestamp_millis()), None => serializer.serialize_none(), } } @@ -1762,7 +1762,7 @@ pub mod serde { where S: ser::Serializer { match *opt { - Some(ref dt) => ts_seconds::serialize(dt, serializer), + Some(ref dt) => serializer.serialize_some(&dt.timestamp()), None => serializer.serialize_none(), } } From 5c4409156055c92d8409ac3c956300991214a577 Mon Sep 17 00:00:00 2001 From: Brandon W Maister Date: Fri, 5 Jun 2020 16:01:06 -0400 Subject: [PATCH 2/2] Add a test for serde option handling in bincode --- src/naive/datetime.rs | 32 +++++++++++++++++++++++++++++--- 1 file changed, 29 insertions(+), 3 deletions(-) diff --git a/src/naive/datetime.rs b/src/naive/datetime.rs index 6989a627e6..fdc2613e66 100644 --- a/src/naive/datetime.rs +++ b/src/naive/datetime.rs @@ -2153,6 +2153,7 @@ pub mod serde { } } + #[cfg(test)] extern crate serde_derive; #[cfg(test)] extern crate serde_json; #[cfg(test)] extern crate bincode; @@ -2166,18 +2167,43 @@ pub mod serde { super::test_decodable_json(|input| self::serde_json::from_str(&input)); } + // Bincode is relevant to test separately from JSON because + // it is not self-describing. #[test] fn test_serde_bincode() { - // Bincode is relevant to test separately from JSON because - // it is not self-describing. - use naive::NaiveDate; use self::bincode::{Infinite, serialize, deserialize}; + use naive::NaiveDate; let dt = NaiveDate::from_ymd(2016, 7, 8).and_hms_milli(9, 10, 48, 90); let encoded = serialize(&dt, Infinite).unwrap(); let decoded: NaiveDateTime = deserialize(&encoded).unwrap(); assert_eq!(dt, decoded); } + + #[test] + fn test_serde_bincode_optional() { + use ::serde::ts_nanoseconds_option; + use self::serde_derive::{Deserialize, Serialize}; + use prelude::*; + use self::bincode::{Infinite, serialize, deserialize}; + + #[derive(Debug, PartialEq, Eq, Serialize, Deserialize)] + struct Test { + one: Option, + #[serde(with = "ts_nanoseconds_option")] + two: Option>, + } + + let expected = Test { + one: Some(1), + two: Some(Utc.ymd(1970, 1, 1).and_hms(0, 1, 1)), + }; + let bytes: Vec = serialize(&expected, Infinite).unwrap(); + let actual = deserialize::(&(bytes)).unwrap(); + + assert_eq!(expected, actual); + + } } #[cfg(test)]