diff --git a/src/types/time.rs b/src/types/time.rs index 4e75cb2..a88c695 100644 --- a/src/types/time.rs +++ b/src/types/time.rs @@ -42,15 +42,27 @@ mod test { fn test_timespec() { let db = checked_memory_handle(); - let ts = time::Timespec { - sec: 10_000, - nsec: 0, - }; - db.execute("INSERT INTO foo(t) VALUES (?)", &[&ts]) - .unwrap(); + let mut ts_vec = vec![]; + + ts_vec.push(time::Timespec::new(10_000, 0));//January 1, 1970 2:46:40 AM + ts_vec.push(time::Timespec::new(10_000, 1000));//January 1, 1970 2:46:40 AM (and one microsecond) + ts_vec.push(time::Timespec::new(1500391124, 1_000_000));//July 18, 2017 + ts_vec.push(time::Timespec::new(2000000000, 2_000_000));//May 18, 2033 + ts_vec.push(time::Timespec::new(3000000000, 999_999_999));//January 24, 2065 + ts_vec.push(time::Timespec::new(10000000000, 0));//November 20, 2286 + + for ts in ts_vec { + + db.execute("INSERT INTO foo(t) VALUES (?)", &[&ts]) + .unwrap(); + + let from: time::Timespec = db.query_row("SELECT t FROM foo", &[], |r| r.get(0)) + .unwrap(); + + db.execute("DELETE FROM foo", &[]).unwrap(); + + assert_eq!(from, ts); + } - let from: time::Timespec = db.query_row("SELECT t FROM foo", &[], |r| r.get(0)) - .unwrap(); - assert_eq!(from, ts); } }