aboutsummaryrefslogtreecommitdiff
path: root/src/primitive/datetime.rs
diff options
context:
space:
mode:
authorMax Audron <audron@cocaine.farm>2021-01-21 14:57:22 +0100
committerMax Audron <audron@cocaine.farm>2021-01-21 14:57:22 +0100
commit2405fa686a53f1d895807b1658c38a5e7e7693a0 (patch)
treed40a9430a421d3ca4a28ce2ad98b51e3d731f265 /src/primitive/datetime.rs
parentMerge branch 'client' (diff)
reorganize tests and add quassel features
Diffstat (limited to 'src/primitive/datetime.rs')
-rw-r--r--src/primitive/datetime.rs34
1 files changed, 34 insertions, 0 deletions
diff --git a/src/primitive/datetime.rs b/src/primitive/datetime.rs
index fadd6a5..e4c4c83 100644
--- a/src/primitive/datetime.rs
+++ b/src/primitive/datetime.rs
@@ -166,3 +166,37 @@ impl Deserialize for Time {
Ok((4, time))
}
}
+
+#[test]
+pub fn datetime_serialize() {
+ let datetime = DateTime::parse("2020-02-19 13:00 +0200", "%Y-%m-%d %R %z").unwrap();
+
+ let sers = datetime.serialize().unwrap();
+ let bytes = vec![0, 37, 133, 19, 2, 202, 28, 128, 3, 0, 0, 28, 32];
+
+ assert_eq!(sers, bytes)
+}
+
+#[test]
+pub fn datetime_deserialize() {
+ let datetime = DateTime::parse("2020-02-19 13:00 +0200", "%Y-%m-%d %R %z").unwrap();
+
+ let bytes = vec![0, 37, 133, 19, 2, 202, 28, 128, 3, 0, 0, 28, 32];
+ let (_, res): (usize, DateTime) = Deserialize::parse(&bytes).unwrap();
+
+ assert_eq!(res, datetime)
+}
+
+#[test]
+pub fn datetime_deserialize_epoch() {
+ let datetime = DateTime::unix_epoch();
+
+ let bytes = vec![0, 37, 133, 19, 0xff, 0xff, 0xff, 0xff, 3, 0, 0, 28, 32];
+ let (_, res): (usize, DateTime) = Deserialize::parse(&bytes).unwrap();
+
+ let bytes = vec![0xff, 0xff, 0xff, 0xff, 2, 202, 28, 128, 3, 0, 0, 28, 32];
+ let (_, res2): (usize, DateTime) = Deserialize::parse(&bytes).unwrap();
+
+ assert_eq!(res, datetime);
+ assert_eq!(res2, datetime)
+}