mirror of
https://github.com/chronotope/chrono.git
synced 2025-09-29 22:11:59 +00:00
Tests: replace TimeDelta::milliseconds
with try_milliseconds
This commit is contained in:
parent
2bf3302ce5
commit
2c1b0bea94
@ -301,7 +301,7 @@ fn test_nanosecond_range() {
|
||||
// Just beyond range
|
||||
let maximum = "2262-04-11T23:47:16.854775804UTC";
|
||||
let parsed: DateTime<Utc> = maximum.parse().unwrap();
|
||||
let beyond_max = parsed + TimeDelta::milliseconds(300);
|
||||
let beyond_max = parsed + TimeDelta::try_milliseconds(300).unwrap();
|
||||
assert!(beyond_max.timestamp_nanos_opt().is_none());
|
||||
|
||||
// Far beyond range
|
||||
|
@ -490,7 +490,7 @@ impl NaiveDateTime {
|
||||
///
|
||||
/// let hmsm = |h, m, s, milli| d.and_hms_milli_opt(h, m, s, milli).unwrap();
|
||||
/// assert_eq!(
|
||||
/// hmsm(3, 5, 7, 980).checked_add_signed(TimeDelta::milliseconds(450)),
|
||||
/// hmsm(3, 5, 7, 980).checked_add_signed(TimeDelta::try_milliseconds(450).unwrap()),
|
||||
/// Some(hmsm(3, 5, 8, 430))
|
||||
/// );
|
||||
/// ```
|
||||
@ -513,11 +513,11 @@ impl NaiveDateTime {
|
||||
/// let leap = hmsm(3, 5, 59, 1_300);
|
||||
/// assert_eq!(leap.checked_add_signed(TimeDelta::zero()),
|
||||
/// Some(hmsm(3, 5, 59, 1_300)));
|
||||
/// assert_eq!(leap.checked_add_signed(TimeDelta::milliseconds(-500)),
|
||||
/// assert_eq!(leap.checked_add_signed(TimeDelta::try_milliseconds(-500).unwrap()),
|
||||
/// Some(hmsm(3, 5, 59, 800)));
|
||||
/// assert_eq!(leap.checked_add_signed(TimeDelta::milliseconds(500)),
|
||||
/// assert_eq!(leap.checked_add_signed(TimeDelta::try_milliseconds(500).unwrap()),
|
||||
/// Some(hmsm(3, 5, 59, 1_800)));
|
||||
/// assert_eq!(leap.checked_add_signed(TimeDelta::milliseconds(800)),
|
||||
/// assert_eq!(leap.checked_add_signed(TimeDelta::try_milliseconds(800).unwrap()),
|
||||
/// Some(hmsm(3, 6, 0, 100)));
|
||||
/// assert_eq!(leap.checked_add_signed(TimeDelta::try_seconds(10).unwrap()),
|
||||
/// Some(hmsm(3, 6, 9, 300)));
|
||||
@ -674,7 +674,7 @@ impl NaiveDateTime {
|
||||
///
|
||||
/// let hmsm = |h, m, s, milli| d.and_hms_milli_opt(h, m, s, milli).unwrap();
|
||||
/// assert_eq!(
|
||||
/// hmsm(3, 5, 7, 450).checked_sub_signed(TimeDelta::milliseconds(670)),
|
||||
/// hmsm(3, 5, 7, 450).checked_sub_signed(TimeDelta::try_milliseconds(670).unwrap()),
|
||||
/// Some(hmsm(3, 5, 6, 780))
|
||||
/// );
|
||||
/// ```
|
||||
@ -697,9 +697,9 @@ impl NaiveDateTime {
|
||||
/// let leap = hmsm(3, 5, 59, 1_300);
|
||||
/// assert_eq!(leap.checked_sub_signed(TimeDelta::zero()),
|
||||
/// Some(hmsm(3, 5, 59, 1_300)));
|
||||
/// assert_eq!(leap.checked_sub_signed(TimeDelta::milliseconds(200)),
|
||||
/// assert_eq!(leap.checked_sub_signed(TimeDelta::try_milliseconds(200).unwrap()),
|
||||
/// Some(hmsm(3, 5, 59, 1_100)));
|
||||
/// assert_eq!(leap.checked_sub_signed(TimeDelta::milliseconds(500)),
|
||||
/// assert_eq!(leap.checked_sub_signed(TimeDelta::try_milliseconds(500).unwrap()),
|
||||
/// Some(hmsm(3, 5, 59, 800)));
|
||||
/// assert_eq!(leap.checked_sub_signed(TimeDelta::try_seconds(60).unwrap()),
|
||||
/// Some(hmsm(3, 5, 0, 300)));
|
||||
@ -794,7 +794,8 @@ impl NaiveDateTime {
|
||||
/// d.and_hms_milli_opt(0, 7, 6, 500)
|
||||
/// .unwrap()
|
||||
/// .signed_duration_since(d0.and_hms_opt(0, 0, 0).unwrap()),
|
||||
/// TimeDelta::try_seconds(189 * 86_400 + 7 * 60 + 6).unwrap() + TimeDelta::milliseconds(500)
|
||||
/// TimeDelta::try_seconds(189 * 86_400 + 7 * 60 + 6).unwrap()
|
||||
/// + TimeDelta::try_milliseconds(500).unwrap()
|
||||
/// );
|
||||
/// ```
|
||||
///
|
||||
@ -807,11 +808,11 @@ impl NaiveDateTime {
|
||||
/// let leap = from_ymd(2015, 6, 30).and_hms_milli_opt(23, 59, 59, 1_500).unwrap();
|
||||
/// assert_eq!(
|
||||
/// leap.signed_duration_since(from_ymd(2015, 6, 30).and_hms_opt(23, 0, 0).unwrap()),
|
||||
/// TimeDelta::try_seconds(3600).unwrap() + TimeDelta::milliseconds(500)
|
||||
/// TimeDelta::try_seconds(3600).unwrap() + TimeDelta::try_milliseconds(500).unwrap()
|
||||
/// );
|
||||
/// assert_eq!(
|
||||
/// from_ymd(2015, 7, 1).and_hms_opt(1, 0, 0).unwrap().signed_duration_since(leap),
|
||||
/// TimeDelta::try_seconds(3600).unwrap() - TimeDelta::milliseconds(500)
|
||||
/// TimeDelta::try_seconds(3600).unwrap() - TimeDelta::try_milliseconds(500).unwrap()
|
||||
/// );
|
||||
/// ```
|
||||
#[must_use]
|
||||
@ -1609,7 +1610,7 @@ impl Timelike for NaiveDateTime {
|
||||
/// );
|
||||
///
|
||||
/// let hmsm = |h, m, s, milli| d.and_hms_milli_opt(h, m, s, milli).unwrap();
|
||||
/// assert_eq!(hmsm(3, 5, 7, 980) + TimeDelta::milliseconds(450), hmsm(3, 5, 8, 430));
|
||||
/// assert_eq!(hmsm(3, 5, 7, 980) + TimeDelta::try_milliseconds(450).unwrap(), hmsm(3, 5, 8, 430));
|
||||
/// ```
|
||||
///
|
||||
/// Leap seconds are handled,
|
||||
@ -1621,9 +1622,9 @@ impl Timelike for NaiveDateTime {
|
||||
/// # let hmsm = |h, m, s, milli| from_ymd(2016, 7, 8).and_hms_milli_opt(h, m, s, milli).unwrap();
|
||||
/// let leap = hmsm(3, 5, 59, 1_300);
|
||||
/// assert_eq!(leap + TimeDelta::zero(), hmsm(3, 5, 59, 1_300));
|
||||
/// assert_eq!(leap + TimeDelta::milliseconds(-500), hmsm(3, 5, 59, 800));
|
||||
/// assert_eq!(leap + TimeDelta::milliseconds(500), hmsm(3, 5, 59, 1_800));
|
||||
/// assert_eq!(leap + TimeDelta::milliseconds(800), hmsm(3, 6, 0, 100));
|
||||
/// assert_eq!(leap + TimeDelta::try_milliseconds(-500).unwrap(), hmsm(3, 5, 59, 800));
|
||||
/// assert_eq!(leap + TimeDelta::try_milliseconds(500).unwrap(), hmsm(3, 5, 59, 1_800));
|
||||
/// assert_eq!(leap + TimeDelta::try_milliseconds(800).unwrap(), hmsm(3, 6, 0, 100));
|
||||
/// assert_eq!(leap + TimeDelta::try_seconds(10).unwrap(), hmsm(3, 6, 9, 300));
|
||||
/// assert_eq!(leap + TimeDelta::try_seconds(-10).unwrap(), hmsm(3, 5, 50, 300));
|
||||
/// assert_eq!(leap + TimeDelta::try_days(1).unwrap(),
|
||||
@ -1799,7 +1800,7 @@ impl Add<Months> for NaiveDateTime {
|
||||
/// );
|
||||
///
|
||||
/// let hmsm = |h, m, s, milli| d.and_hms_milli_opt(h, m, s, milli).unwrap();
|
||||
/// assert_eq!(hmsm(3, 5, 7, 450) - TimeDelta::milliseconds(670), hmsm(3, 5, 6, 780));
|
||||
/// assert_eq!(hmsm(3, 5, 7, 450) - TimeDelta::try_milliseconds(670).unwrap(), hmsm(3, 5, 6, 780));
|
||||
/// ```
|
||||
///
|
||||
/// Leap seconds are handled,
|
||||
@ -1811,8 +1812,8 @@ impl Add<Months> for NaiveDateTime {
|
||||
/// # let hmsm = |h, m, s, milli| from_ymd(2016, 7, 8).and_hms_milli_opt(h, m, s, milli).unwrap();
|
||||
/// let leap = hmsm(3, 5, 59, 1_300);
|
||||
/// assert_eq!(leap - TimeDelta::zero(), hmsm(3, 5, 59, 1_300));
|
||||
/// assert_eq!(leap - TimeDelta::milliseconds(200), hmsm(3, 5, 59, 1_100));
|
||||
/// assert_eq!(leap - TimeDelta::milliseconds(500), hmsm(3, 5, 59, 800));
|
||||
/// assert_eq!(leap - TimeDelta::try_milliseconds(200).unwrap(), hmsm(3, 5, 59, 1_100));
|
||||
/// assert_eq!(leap - TimeDelta::try_milliseconds(500).unwrap(), hmsm(3, 5, 59, 800));
|
||||
/// assert_eq!(leap - TimeDelta::try_seconds(60).unwrap(), hmsm(3, 5, 0, 300));
|
||||
/// assert_eq!(leap - TimeDelta::try_days(1).unwrap(),
|
||||
/// from_ymd(2016, 7, 7).and_hms_milli_opt(3, 6, 0, 300).unwrap());
|
||||
@ -1967,7 +1968,8 @@ impl Sub<Months> for NaiveDateTime {
|
||||
/// let d0 = from_ymd(2016, 1, 1);
|
||||
/// assert_eq!(
|
||||
/// d.and_hms_milli_opt(0, 7, 6, 500).unwrap() - d0.and_hms_opt(0, 0, 0).unwrap(),
|
||||
/// TimeDelta::try_seconds(189 * 86_400 + 7 * 60 + 6).unwrap() + TimeDelta::milliseconds(500)
|
||||
/// TimeDelta::try_seconds(189 * 86_400 + 7 * 60 + 6).unwrap()
|
||||
/// + TimeDelta::try_milliseconds(500).unwrap()
|
||||
/// );
|
||||
/// ```
|
||||
///
|
||||
@ -1980,11 +1982,11 @@ impl Sub<Months> for NaiveDateTime {
|
||||
/// let leap = from_ymd(2015, 6, 30).and_hms_milli_opt(23, 59, 59, 1_500).unwrap();
|
||||
/// assert_eq!(
|
||||
/// leap - from_ymd(2015, 6, 30).and_hms_opt(23, 0, 0).unwrap(),
|
||||
/// TimeDelta::try_seconds(3600).unwrap() + TimeDelta::milliseconds(500)
|
||||
/// TimeDelta::try_seconds(3600).unwrap() + TimeDelta::try_milliseconds(500).unwrap()
|
||||
/// );
|
||||
/// assert_eq!(
|
||||
/// from_ymd(2015, 7, 1).and_hms_opt(1, 0, 0).unwrap() - leap,
|
||||
/// TimeDelta::try_seconds(3600).unwrap() - TimeDelta::milliseconds(500)
|
||||
/// TimeDelta::try_seconds(3600).unwrap() - TimeDelta::try_milliseconds(500).unwrap()
|
||||
/// );
|
||||
/// ```
|
||||
impl Sub<NaiveDateTime> for NaiveDateTime {
|
||||
|
@ -696,11 +696,11 @@ impl NaiveTime {
|
||||
/// assert_eq!(since(from_hmsm(3, 5, 7, 900), from_hmsm(3, 5, 7, 900)), TimeDelta::zero());
|
||||
/// assert_eq!(
|
||||
/// since(from_hmsm(3, 5, 7, 900), from_hmsm(3, 5, 7, 875)),
|
||||
/// TimeDelta::milliseconds(25)
|
||||
/// TimeDelta::try_milliseconds(25).unwrap()
|
||||
/// );
|
||||
/// assert_eq!(
|
||||
/// since(from_hmsm(3, 5, 7, 900), from_hmsm(3, 5, 6, 925)),
|
||||
/// TimeDelta::milliseconds(975)
|
||||
/// TimeDelta::try_milliseconds(975).unwrap()
|
||||
/// );
|
||||
/// assert_eq!(
|
||||
/// since(from_hmsm(3, 5, 7, 900), from_hmsm(3, 5, 0, 900)),
|
||||
@ -720,7 +720,7 @@ impl NaiveTime {
|
||||
/// );
|
||||
/// assert_eq!(
|
||||
/// since(from_hmsm(3, 5, 7, 900), from_hmsm(2, 4, 6, 800)),
|
||||
/// TimeDelta::try_seconds(3600 + 60 + 1).unwrap() + TimeDelta::milliseconds(100)
|
||||
/// TimeDelta::try_seconds(3600 + 60 + 1).unwrap() + TimeDelta::try_milliseconds(100).unwrap()
|
||||
/// );
|
||||
/// ```
|
||||
///
|
||||
@ -734,7 +734,7 @@ impl NaiveTime {
|
||||
/// assert_eq!(since(from_hmsm(3, 0, 59, 1_000), from_hmsm(3, 0, 59, 0)),
|
||||
/// TimeDelta::try_seconds(1).unwrap());
|
||||
/// assert_eq!(since(from_hmsm(3, 0, 59, 1_500), from_hmsm(3, 0, 59, 0)),
|
||||
/// TimeDelta::milliseconds(1500));
|
||||
/// TimeDelta::try_milliseconds(1500).unwrap());
|
||||
/// assert_eq!(since(from_hmsm(3, 0, 59, 1_000), from_hmsm(3, 0, 0, 0)),
|
||||
/// TimeDelta::try_seconds(60).unwrap());
|
||||
/// assert_eq!(since(from_hmsm(3, 0, 0, 0), from_hmsm(2, 59, 59, 1_000)),
|
||||
@ -1166,9 +1166,18 @@ impl Timelike for NaiveTime {
|
||||
/// from_hmsm(3, 5, 7, 0) + TimeDelta::try_seconds(7 * 60 * 60 - 6 * 60).unwrap(),
|
||||
/// from_hmsm(9, 59, 7, 0)
|
||||
/// );
|
||||
/// assert_eq!(from_hmsm(3, 5, 7, 0) + TimeDelta::milliseconds(80), from_hmsm(3, 5, 7, 80));
|
||||
/// assert_eq!(from_hmsm(3, 5, 7, 950) + TimeDelta::milliseconds(280), from_hmsm(3, 5, 8, 230));
|
||||
/// assert_eq!(from_hmsm(3, 5, 7, 950) + TimeDelta::milliseconds(-980), from_hmsm(3, 5, 6, 970));
|
||||
/// assert_eq!(
|
||||
/// from_hmsm(3, 5, 7, 0) + TimeDelta::try_milliseconds(80).unwrap(),
|
||||
/// from_hmsm(3, 5, 7, 80)
|
||||
/// );
|
||||
/// assert_eq!(
|
||||
/// from_hmsm(3, 5, 7, 950) + TimeDelta::try_milliseconds(280).unwrap(),
|
||||
/// from_hmsm(3, 5, 8, 230)
|
||||
/// );
|
||||
/// assert_eq!(
|
||||
/// from_hmsm(3, 5, 7, 950) + TimeDelta::try_milliseconds(-980).unwrap(),
|
||||
/// from_hmsm(3, 5, 6, 970)
|
||||
/// );
|
||||
/// ```
|
||||
///
|
||||
/// The addition wraps around.
|
||||
@ -1188,9 +1197,9 @@ impl Timelike for NaiveTime {
|
||||
/// # let from_hmsm = |h, m, s, milli| { NaiveTime::from_hms_milli_opt(h, m, s, milli).unwrap() };
|
||||
/// let leap = from_hmsm(3, 5, 59, 1_300);
|
||||
/// assert_eq!(leap + TimeDelta::zero(), from_hmsm(3, 5, 59, 1_300));
|
||||
/// assert_eq!(leap + TimeDelta::milliseconds(-500), from_hmsm(3, 5, 59, 800));
|
||||
/// assert_eq!(leap + TimeDelta::milliseconds(500), from_hmsm(3, 5, 59, 1_800));
|
||||
/// assert_eq!(leap + TimeDelta::milliseconds(800), from_hmsm(3, 6, 0, 100));
|
||||
/// assert_eq!(leap + TimeDelta::try_milliseconds(-500).unwrap(), from_hmsm(3, 5, 59, 800));
|
||||
/// assert_eq!(leap + TimeDelta::try_milliseconds(500).unwrap(), from_hmsm(3, 5, 59, 1_800));
|
||||
/// assert_eq!(leap + TimeDelta::try_milliseconds(800).unwrap(), from_hmsm(3, 6, 0, 100));
|
||||
/// assert_eq!(leap + TimeDelta::try_seconds(10).unwrap(), from_hmsm(3, 6, 9, 300));
|
||||
/// assert_eq!(leap + TimeDelta::try_seconds(-10).unwrap(), from_hmsm(3, 5, 50, 300));
|
||||
/// assert_eq!(leap + TimeDelta::try_days(1).unwrap(), from_hmsm(3, 5, 59, 300));
|
||||
@ -1286,8 +1295,14 @@ impl Add<FixedOffset> for NaiveTime {
|
||||
/// from_hmsm(3, 5, 7, 0) - TimeDelta::try_seconds(2 * 60 * 60 + 6 * 60).unwrap(),
|
||||
/// from_hmsm(0, 59, 7, 0)
|
||||
/// );
|
||||
/// assert_eq!(from_hmsm(3, 5, 7, 0) - TimeDelta::milliseconds(80), from_hmsm(3, 5, 6, 920));
|
||||
/// assert_eq!(from_hmsm(3, 5, 7, 950) - TimeDelta::milliseconds(280), from_hmsm(3, 5, 7, 670));
|
||||
/// assert_eq!(
|
||||
/// from_hmsm(3, 5, 7, 0) - TimeDelta::try_milliseconds(80).unwrap(),
|
||||
/// from_hmsm(3, 5, 6, 920)
|
||||
/// );
|
||||
/// assert_eq!(
|
||||
/// from_hmsm(3, 5, 7, 950) - TimeDelta::try_milliseconds(280).unwrap(),
|
||||
/// from_hmsm(3, 5, 7, 670)
|
||||
/// );
|
||||
/// ```
|
||||
///
|
||||
/// The subtraction wraps around.
|
||||
@ -1306,8 +1321,8 @@ impl Add<FixedOffset> for NaiveTime {
|
||||
/// # let from_hmsm = |h, m, s, milli| { NaiveTime::from_hms_milli_opt(h, m, s, milli).unwrap() };
|
||||
/// let leap = from_hmsm(3, 5, 59, 1_300);
|
||||
/// assert_eq!(leap - TimeDelta::zero(), from_hmsm(3, 5, 59, 1_300));
|
||||
/// assert_eq!(leap - TimeDelta::milliseconds(200), from_hmsm(3, 5, 59, 1_100));
|
||||
/// assert_eq!(leap - TimeDelta::milliseconds(500), from_hmsm(3, 5, 59, 800));
|
||||
/// assert_eq!(leap - TimeDelta::try_milliseconds(200).unwrap(), from_hmsm(3, 5, 59, 1_100));
|
||||
/// assert_eq!(leap - TimeDelta::try_milliseconds(500).unwrap(), from_hmsm(3, 5, 59, 800));
|
||||
/// assert_eq!(leap - TimeDelta::try_seconds(60).unwrap(), from_hmsm(3, 5, 0, 300));
|
||||
/// assert_eq!(leap - TimeDelta::try_days(1).unwrap(), from_hmsm(3, 6, 0, 300));
|
||||
/// ```
|
||||
@ -1396,8 +1411,14 @@ impl Sub<FixedOffset> for NaiveTime {
|
||||
/// let from_hmsm = |h, m, s, milli| NaiveTime::from_hms_milli_opt(h, m, s, milli).unwrap();
|
||||
///
|
||||
/// assert_eq!(from_hmsm(3, 5, 7, 900) - from_hmsm(3, 5, 7, 900), TimeDelta::zero());
|
||||
/// assert_eq!(from_hmsm(3, 5, 7, 900) - from_hmsm(3, 5, 7, 875), TimeDelta::milliseconds(25));
|
||||
/// assert_eq!(from_hmsm(3, 5, 7, 900) - from_hmsm(3, 5, 6, 925), TimeDelta::milliseconds(975));
|
||||
/// assert_eq!(
|
||||
/// from_hmsm(3, 5, 7, 900) - from_hmsm(3, 5, 7, 875),
|
||||
/// TimeDelta::try_milliseconds(25).unwrap()
|
||||
/// );
|
||||
/// assert_eq!(
|
||||
/// from_hmsm(3, 5, 7, 900) - from_hmsm(3, 5, 6, 925),
|
||||
/// TimeDelta::try_milliseconds(975).unwrap()
|
||||
/// );
|
||||
/// assert_eq!(
|
||||
/// from_hmsm(3, 5, 7, 900) - from_hmsm(3, 5, 0, 900),
|
||||
/// TimeDelta::try_seconds(7).unwrap()
|
||||
@ -1416,7 +1437,7 @@ impl Sub<FixedOffset> for NaiveTime {
|
||||
/// );
|
||||
/// assert_eq!(
|
||||
/// from_hmsm(3, 5, 7, 900) - from_hmsm(2, 4, 6, 800),
|
||||
/// TimeDelta::try_seconds(3600 + 60 + 1).unwrap() + TimeDelta::milliseconds(100)
|
||||
/// TimeDelta::try_seconds(3600 + 60 + 1).unwrap() + TimeDelta::try_milliseconds(100).unwrap()
|
||||
/// );
|
||||
/// ```
|
||||
///
|
||||
@ -1428,7 +1449,7 @@ impl Sub<FixedOffset> for NaiveTime {
|
||||
/// # let from_hmsm = |h, m, s, milli| { NaiveTime::from_hms_milli_opt(h, m, s, milli).unwrap() };
|
||||
/// assert_eq!(from_hmsm(3, 0, 59, 1_000) - from_hmsm(3, 0, 59, 0), TimeDelta::try_seconds(1).unwrap());
|
||||
/// assert_eq!(from_hmsm(3, 0, 59, 1_500) - from_hmsm(3, 0, 59, 0),
|
||||
/// TimeDelta::milliseconds(1500));
|
||||
/// TimeDelta::try_milliseconds(1500).unwrap());
|
||||
/// assert_eq!(from_hmsm(3, 0, 59, 1_000) - from_hmsm(3, 0, 0, 0), TimeDelta::try_seconds(60).unwrap());
|
||||
/// assert_eq!(from_hmsm(3, 0, 0, 0) - from_hmsm(2, 59, 59, 1_000), TimeDelta::try_seconds(1).unwrap());
|
||||
/// assert_eq!(from_hmsm(3, 0, 59, 1_000) - from_hmsm(2, 59, 59, 1_000),
|
||||
|
@ -94,13 +94,17 @@ fn test_time_add() {
|
||||
let hmsm = |h, m, s, ms| NaiveTime::from_hms_milli_opt(h, m, s, ms).unwrap();
|
||||
|
||||
check!(hmsm(3, 5, 59, 900), TimeDelta::zero(), hmsm(3, 5, 59, 900));
|
||||
check!(hmsm(3, 5, 59, 900), TimeDelta::milliseconds(100), hmsm(3, 6, 0, 0));
|
||||
check!(hmsm(3, 5, 59, 1_300), TimeDelta::milliseconds(-1800), hmsm(3, 5, 58, 500));
|
||||
check!(hmsm(3, 5, 59, 1_300), TimeDelta::milliseconds(-800), hmsm(3, 5, 59, 500));
|
||||
check!(hmsm(3, 5, 59, 1_300), TimeDelta::milliseconds(-100), hmsm(3, 5, 59, 1_200));
|
||||
check!(hmsm(3, 5, 59, 1_300), TimeDelta::milliseconds(100), hmsm(3, 5, 59, 1_400));
|
||||
check!(hmsm(3, 5, 59, 1_300), TimeDelta::milliseconds(800), hmsm(3, 6, 0, 100));
|
||||
check!(hmsm(3, 5, 59, 1_300), TimeDelta::milliseconds(1800), hmsm(3, 6, 1, 100));
|
||||
check!(hmsm(3, 5, 59, 900), TimeDelta::try_milliseconds(100).unwrap(), hmsm(3, 6, 0, 0));
|
||||
check!(hmsm(3, 5, 59, 1_300), TimeDelta::try_milliseconds(-1800).unwrap(), hmsm(3, 5, 58, 500));
|
||||
check!(hmsm(3, 5, 59, 1_300), TimeDelta::try_milliseconds(-800).unwrap(), hmsm(3, 5, 59, 500));
|
||||
check!(
|
||||
hmsm(3, 5, 59, 1_300),
|
||||
TimeDelta::try_milliseconds(-100).unwrap(),
|
||||
hmsm(3, 5, 59, 1_200)
|
||||
);
|
||||
check!(hmsm(3, 5, 59, 1_300), TimeDelta::try_milliseconds(100).unwrap(), hmsm(3, 5, 59, 1_400));
|
||||
check!(hmsm(3, 5, 59, 1_300), TimeDelta::try_milliseconds(800).unwrap(), hmsm(3, 6, 0, 100));
|
||||
check!(hmsm(3, 5, 59, 1_300), TimeDelta::try_milliseconds(1800).unwrap(), hmsm(3, 6, 1, 100));
|
||||
check!(hmsm(3, 5, 59, 900), TimeDelta::try_seconds(86399).unwrap(), hmsm(3, 5, 58, 900)); // overwrap
|
||||
check!(hmsm(3, 5, 59, 900), TimeDelta::try_seconds(-86399).unwrap(), hmsm(3, 6, 0, 900));
|
||||
check!(hmsm(3, 5, 59, 900), TimeDelta::try_days(12345).unwrap(), hmsm(3, 5, 59, 900));
|
||||
@ -108,8 +112,8 @@ fn test_time_add() {
|
||||
check!(hmsm(3, 5, 59, 1_300), TimeDelta::try_days(-1).unwrap(), hmsm(3, 6, 0, 300));
|
||||
|
||||
// regression tests for #37
|
||||
check!(hmsm(0, 0, 0, 0), TimeDelta::milliseconds(-990), hmsm(23, 59, 59, 10));
|
||||
check!(hmsm(0, 0, 0, 0), TimeDelta::milliseconds(-9990), hmsm(23, 59, 50, 10));
|
||||
check!(hmsm(0, 0, 0, 0), TimeDelta::try_milliseconds(-990).unwrap(), hmsm(23, 59, 59, 10));
|
||||
check!(hmsm(0, 0, 0, 0), TimeDelta::try_milliseconds(-9990).unwrap(), hmsm(23, 59, 50, 10));
|
||||
}
|
||||
|
||||
#[test]
|
||||
@ -173,24 +177,24 @@ fn test_time_sub() {
|
||||
let hmsm = |h, m, s, ms| NaiveTime::from_hms_milli_opt(h, m, s, ms).unwrap();
|
||||
|
||||
check!(hmsm(3, 5, 7, 900), hmsm(3, 5, 7, 900), TimeDelta::zero());
|
||||
check!(hmsm(3, 5, 7, 900), hmsm(3, 5, 7, 600), TimeDelta::milliseconds(300));
|
||||
check!(hmsm(3, 5, 7, 900), hmsm(3, 5, 7, 600), TimeDelta::try_milliseconds(300).unwrap());
|
||||
check!(hmsm(3, 5, 7, 200), hmsm(2, 4, 6, 200), TimeDelta::try_seconds(3600 + 60 + 1).unwrap());
|
||||
check!(
|
||||
hmsm(3, 5, 7, 200),
|
||||
hmsm(2, 4, 6, 300),
|
||||
TimeDelta::try_seconds(3600 + 60).unwrap() + TimeDelta::milliseconds(900)
|
||||
TimeDelta::try_seconds(3600 + 60).unwrap() + TimeDelta::try_milliseconds(900).unwrap()
|
||||
);
|
||||
|
||||
// treats the leap second as if it coincides with the prior non-leap second,
|
||||
// as required by `time1 - time2 = duration` and `time2 - time1 = -duration` equivalence.
|
||||
check!(hmsm(3, 6, 0, 200), hmsm(3, 5, 59, 1_800), TimeDelta::milliseconds(400));
|
||||
//check!(hmsm(3, 5, 7, 1_200), hmsm(3, 5, 6, 1_800), TimeDelta::milliseconds(1400));
|
||||
//check!(hmsm(3, 5, 7, 1_200), hmsm(3, 5, 6, 800), TimeDelta::milliseconds(1400));
|
||||
check!(hmsm(3, 6, 0, 200), hmsm(3, 5, 59, 1_800), TimeDelta::try_milliseconds(400).unwrap());
|
||||
//check!(hmsm(3, 5, 7, 1_200), hmsm(3, 5, 6, 1_800), TimeDelta::try_milliseconds(1400).unwrap());
|
||||
//check!(hmsm(3, 5, 7, 1_200), hmsm(3, 5, 6, 800), TimeDelta::try_milliseconds(1400).unwrap());
|
||||
|
||||
// additional equality: `time1 + duration = time2` is equivalent to
|
||||
// `time2 - time1 = duration` IF AND ONLY IF `time2` represents a non-leap second.
|
||||
assert_eq!(hmsm(3, 5, 6, 800) + TimeDelta::milliseconds(400), hmsm(3, 5, 7, 200));
|
||||
//assert_eq!(hmsm(3, 5, 6, 1_800) + TimeDelta::milliseconds(400), hmsm(3, 5, 7, 200));
|
||||
assert_eq!(hmsm(3, 5, 6, 800) + TimeDelta::try_milliseconds(400).unwrap(), hmsm(3, 5, 7, 200));
|
||||
//assert_eq!(hmsm(3, 5, 6, 1_800) + TimeDelta::try_milliseconds(400).unwrap(), hmsm(3, 5, 7, 200));
|
||||
}
|
||||
|
||||
#[test]
|
||||
|
12
src/round.rs
12
src/round.rs
@ -127,7 +127,7 @@ pub trait DurationRound: Sized {
|
||||
/// .and_local_timezone(Utc)
|
||||
/// .unwrap();
|
||||
/// assert_eq!(
|
||||
/// dt.duration_round(TimeDelta::milliseconds(10)).unwrap().to_string(),
|
||||
/// dt.duration_round(TimeDelta::try_milliseconds(10).unwrap()).unwrap().to_string(),
|
||||
/// "2018-01-11 12:00:00.150 UTC"
|
||||
/// );
|
||||
/// assert_eq!(
|
||||
@ -149,7 +149,7 @@ pub trait DurationRound: Sized {
|
||||
/// .and_local_timezone(Utc)
|
||||
/// .unwrap();
|
||||
/// assert_eq!(
|
||||
/// dt.duration_trunc(TimeDelta::milliseconds(10)).unwrap().to_string(),
|
||||
/// dt.duration_trunc(TimeDelta::try_milliseconds(10).unwrap()).unwrap().to_string(),
|
||||
/// "2018-01-11 12:00:00.150 UTC"
|
||||
/// );
|
||||
/// assert_eq!(
|
||||
@ -464,7 +464,7 @@ mod tests {
|
||||
);
|
||||
|
||||
assert_eq!(
|
||||
dt.duration_round(TimeDelta::milliseconds(10)).unwrap().to_string(),
|
||||
dt.duration_round(TimeDelta::try_milliseconds(10).unwrap()).unwrap().to_string(),
|
||||
"2016-12-31 23:59:59.180 UTC"
|
||||
);
|
||||
|
||||
@ -555,7 +555,7 @@ mod tests {
|
||||
);
|
||||
|
||||
assert_eq!(
|
||||
dt.duration_round(TimeDelta::milliseconds(10)).unwrap().to_string(),
|
||||
dt.duration_round(TimeDelta::try_milliseconds(10).unwrap()).unwrap().to_string(),
|
||||
"2016-12-31 23:59:59.180"
|
||||
);
|
||||
|
||||
@ -627,7 +627,7 @@ mod tests {
|
||||
.unwrap();
|
||||
|
||||
assert_eq!(
|
||||
dt.duration_trunc(TimeDelta::milliseconds(10)).unwrap().to_string(),
|
||||
dt.duration_trunc(TimeDelta::try_milliseconds(10).unwrap()).unwrap().to_string(),
|
||||
"2016-12-31 23:59:59.170 UTC"
|
||||
);
|
||||
|
||||
@ -712,7 +712,7 @@ mod tests {
|
||||
.naive_utc();
|
||||
|
||||
assert_eq!(
|
||||
dt.duration_trunc(TimeDelta::milliseconds(10)).unwrap().to_string(),
|
||||
dt.duration_trunc(TimeDelta::try_milliseconds(10).unwrap()).unwrap().to_string(),
|
||||
"2016-12-31 23:59:59.170"
|
||||
);
|
||||
|
||||
|
@ -227,6 +227,7 @@ impl TimeDelta {
|
||||
/// Panics when the `TimeDelta` would be out of bounds, i.e. when `milliseconds` is more than
|
||||
/// `i64::MAX` or less than `-i64::MAX`. Notably, this is not the same as `i64::MIN`.
|
||||
#[inline]
|
||||
#[deprecated]
|
||||
pub const fn milliseconds(milliseconds: i64) -> TimeDelta {
|
||||
expect!(TimeDelta::try_milliseconds(milliseconds), "TimeDelta::milliseconds out of bounds")
|
||||
}
|
||||
@ -660,10 +661,10 @@ mod tests {
|
||||
assert_eq!(TimeDelta::zero().num_seconds(), 0);
|
||||
assert_eq!(TimeDelta::try_seconds(1).unwrap().num_seconds(), 1);
|
||||
assert_eq!(TimeDelta::try_seconds(-1).unwrap().num_seconds(), -1);
|
||||
assert_eq!(TimeDelta::milliseconds(999).num_seconds(), 0);
|
||||
assert_eq!(TimeDelta::milliseconds(1001).num_seconds(), 1);
|
||||
assert_eq!(TimeDelta::milliseconds(-999).num_seconds(), 0);
|
||||
assert_eq!(TimeDelta::milliseconds(-1001).num_seconds(), -1);
|
||||
assert_eq!(TimeDelta::try_milliseconds(999).unwrap().num_seconds(), 0);
|
||||
assert_eq!(TimeDelta::try_milliseconds(1001).unwrap().num_seconds(), 1);
|
||||
assert_eq!(TimeDelta::try_milliseconds(-999).unwrap().num_seconds(), 0);
|
||||
assert_eq!(TimeDelta::try_milliseconds(-1001).unwrap().num_seconds(), -1);
|
||||
}
|
||||
|
||||
#[test]
|
||||
@ -711,8 +712,8 @@ mod tests {
|
||||
#[test]
|
||||
fn test_duration_num_milliseconds() {
|
||||
assert_eq!(TimeDelta::zero().num_milliseconds(), 0);
|
||||
assert_eq!(TimeDelta::milliseconds(1).num_milliseconds(), 1);
|
||||
assert_eq!(TimeDelta::milliseconds(-1).num_milliseconds(), -1);
|
||||
assert_eq!(TimeDelta::try_milliseconds(1).unwrap().num_milliseconds(), 1);
|
||||
assert_eq!(TimeDelta::try_milliseconds(-1).unwrap().num_milliseconds(), -1);
|
||||
assert_eq!(TimeDelta::microseconds(999).num_milliseconds(), 0);
|
||||
assert_eq!(TimeDelta::microseconds(1001).num_milliseconds(), 1);
|
||||
assert_eq!(TimeDelta::microseconds(-999).num_milliseconds(), 0);
|
||||
@ -723,7 +724,7 @@ mod tests {
|
||||
fn test_duration_milliseconds_max_allowed() {
|
||||
// The maximum number of milliseconds acceptable through the constructor is
|
||||
// equal to the number that can be stored in a TimeDelta.
|
||||
let duration = TimeDelta::milliseconds(i64::MAX);
|
||||
let duration = TimeDelta::try_milliseconds(i64::MAX).unwrap();
|
||||
assert_eq!(duration.num_milliseconds(), i64::MAX);
|
||||
assert_eq!(
|
||||
duration.secs as i128 * 1_000_000_000 + duration.nanos as i128,
|
||||
@ -735,8 +736,9 @@ mod tests {
|
||||
fn test_duration_milliseconds_max_overflow() {
|
||||
// Here we ensure that trying to add one millisecond to the maximum storable
|
||||
// value will fail.
|
||||
assert!(TimeDelta::milliseconds(i64::MAX)
|
||||
.checked_add(&TimeDelta::milliseconds(1))
|
||||
assert!(TimeDelta::try_milliseconds(i64::MAX)
|
||||
.unwrap()
|
||||
.checked_add(&TimeDelta::try_milliseconds(1).unwrap())
|
||||
.is_none());
|
||||
}
|
||||
|
||||
@ -745,7 +747,7 @@ mod tests {
|
||||
// The minimum number of milliseconds acceptable through the constructor is
|
||||
// not equal to the number that can be stored in a TimeDelta - there is a
|
||||
// difference of one (i64::MIN vs -i64::MAX).
|
||||
let duration = TimeDelta::milliseconds(-i64::MAX);
|
||||
let duration = TimeDelta::try_milliseconds(-i64::MAX).unwrap();
|
||||
assert_eq!(duration.num_milliseconds(), -i64::MAX);
|
||||
assert_eq!(
|
||||
duration.secs as i128 * 1_000_000_000 + duration.nanos as i128,
|
||||
@ -757,8 +759,9 @@ mod tests {
|
||||
fn test_duration_milliseconds_min_underflow() {
|
||||
// Here we ensure that trying to subtract one millisecond from the minimum
|
||||
// storable value will fail.
|
||||
assert!(TimeDelta::milliseconds(-i64::MAX)
|
||||
.checked_sub(&TimeDelta::milliseconds(1))
|
||||
assert!(TimeDelta::try_milliseconds(-i64::MAX)
|
||||
.unwrap()
|
||||
.checked_sub(&TimeDelta::try_milliseconds(1).unwrap())
|
||||
.is_none());
|
||||
}
|
||||
|
||||
@ -816,7 +819,7 @@ mod tests {
|
||||
// microseconds by creating a TimeDelta with the maximum number of
|
||||
// milliseconds and then checking that the number of microseconds matches
|
||||
// the storage limit.
|
||||
let duration = TimeDelta::milliseconds(i64::MAX);
|
||||
let duration = TimeDelta::try_milliseconds(i64::MAX).unwrap();
|
||||
assert!(duration.num_microseconds().is_none());
|
||||
assert_eq!(
|
||||
duration.secs as i128 * 1_000_000_000 + duration.nanos as i128,
|
||||
@ -835,7 +838,8 @@ mod tests {
|
||||
);
|
||||
// Here we ensure that trying to add one microsecond to the maximum storable
|
||||
// value will fail.
|
||||
assert!(TimeDelta::milliseconds(i64::MAX)
|
||||
assert!(TimeDelta::try_milliseconds(i64::MAX)
|
||||
.unwrap()
|
||||
.checked_add(&TimeDelta::microseconds(1))
|
||||
.is_none());
|
||||
}
|
||||
@ -854,7 +858,7 @@ mod tests {
|
||||
// microseconds by creating a TimeDelta with the minimum number of
|
||||
// milliseconds and then checking that the number of microseconds matches
|
||||
// the storage limit.
|
||||
let duration = TimeDelta::milliseconds(-i64::MAX);
|
||||
let duration = TimeDelta::try_milliseconds(-i64::MAX).unwrap();
|
||||
assert!(duration.num_microseconds().is_none());
|
||||
assert_eq!(
|
||||
duration.secs as i128 * 1_000_000_000 + duration.nanos as i128,
|
||||
@ -873,7 +877,8 @@ mod tests {
|
||||
);
|
||||
// Here we ensure that trying to subtract one microsecond from the minimum
|
||||
// storable value will fail.
|
||||
assert!(TimeDelta::milliseconds(-i64::MAX)
|
||||
assert!(TimeDelta::try_milliseconds(-i64::MAX)
|
||||
.unwrap()
|
||||
.checked_sub(&TimeDelta::microseconds(1))
|
||||
.is_none());
|
||||
}
|
||||
@ -917,7 +922,7 @@ mod tests {
|
||||
// Here we create a TimeDelta with the maximum possible number of nanoseconds
|
||||
// by creating a TimeDelta with the maximum number of milliseconds and then
|
||||
// checking that the number of nanoseconds matches the storage limit.
|
||||
let duration = TimeDelta::milliseconds(i64::MAX);
|
||||
let duration = TimeDelta::try_milliseconds(i64::MAX).unwrap();
|
||||
assert!(duration.num_nanoseconds().is_none());
|
||||
assert_eq!(
|
||||
duration.secs as i128 * 1_000_000_000 + duration.nanos as i128,
|
||||
@ -937,7 +942,8 @@ mod tests {
|
||||
);
|
||||
// Here we ensure that trying to add one nanosecond to the maximum storable
|
||||
// value will fail.
|
||||
assert!(TimeDelta::milliseconds(i64::MAX)
|
||||
assert!(TimeDelta::try_milliseconds(i64::MAX)
|
||||
.unwrap()
|
||||
.checked_add(&TimeDelta::nanoseconds(1))
|
||||
.is_none());
|
||||
}
|
||||
@ -956,7 +962,7 @@ mod tests {
|
||||
// Here we create a TimeDelta with the minimum possible number of nanoseconds
|
||||
// by creating a TimeDelta with the minimum number of milliseconds and then
|
||||
// checking that the number of nanoseconds matches the storage limit.
|
||||
let duration = TimeDelta::milliseconds(-i64::MAX);
|
||||
let duration = TimeDelta::try_milliseconds(-i64::MAX).unwrap();
|
||||
assert!(duration.num_nanoseconds().is_none());
|
||||
assert_eq!(
|
||||
duration.secs as i128 * 1_000_000_000 + duration.nanos as i128,
|
||||
@ -976,7 +982,8 @@ mod tests {
|
||||
);
|
||||
// Here we ensure that trying to subtract one nanosecond from the minimum
|
||||
// storable value will fail.
|
||||
assert!(TimeDelta::milliseconds(-i64::MAX)
|
||||
assert!(TimeDelta::try_milliseconds(-i64::MAX)
|
||||
.unwrap()
|
||||
.checked_sub(&TimeDelta::nanoseconds(1))
|
||||
.is_none());
|
||||
}
|
||||
@ -987,7 +994,7 @@ mod tests {
|
||||
MAX.secs as i128 * 1_000_000_000 + MAX.nanos as i128,
|
||||
i64::MAX as i128 * 1_000_000
|
||||
);
|
||||
assert_eq!(MAX, TimeDelta::milliseconds(i64::MAX));
|
||||
assert_eq!(MAX, TimeDelta::try_milliseconds(i64::MAX).unwrap());
|
||||
assert_eq!(MAX.num_milliseconds(), i64::MAX);
|
||||
assert_eq!(MAX.num_microseconds(), None);
|
||||
assert_eq!(MAX.num_nanoseconds(), None);
|
||||
@ -999,7 +1006,7 @@ mod tests {
|
||||
MIN.secs as i128 * 1_000_000_000 + MIN.nanos as i128,
|
||||
-i64::MAX as i128 * 1_000_000
|
||||
);
|
||||
assert_eq!(MIN, TimeDelta::milliseconds(-i64::MAX));
|
||||
assert_eq!(MIN, TimeDelta::try_milliseconds(-i64::MAX).unwrap());
|
||||
assert_eq!(MIN.num_milliseconds(), -i64::MAX);
|
||||
assert_eq!(MIN.num_microseconds(), None);
|
||||
assert_eq!(MIN.num_nanoseconds(), None);
|
||||
@ -1007,67 +1014,65 @@ mod tests {
|
||||
|
||||
#[test]
|
||||
fn test_duration_ord() {
|
||||
assert!(TimeDelta::milliseconds(1) < TimeDelta::milliseconds(2));
|
||||
assert!(TimeDelta::milliseconds(2) > TimeDelta::milliseconds(1));
|
||||
assert!(TimeDelta::milliseconds(-1) > TimeDelta::milliseconds(-2));
|
||||
assert!(TimeDelta::milliseconds(-2) < TimeDelta::milliseconds(-1));
|
||||
assert!(TimeDelta::milliseconds(-1) < TimeDelta::milliseconds(1));
|
||||
assert!(TimeDelta::milliseconds(1) > TimeDelta::milliseconds(-1));
|
||||
assert!(TimeDelta::milliseconds(0) < TimeDelta::milliseconds(1));
|
||||
assert!(TimeDelta::milliseconds(0) > TimeDelta::milliseconds(-1));
|
||||
assert!(TimeDelta::milliseconds(1_001) < TimeDelta::milliseconds(1_002));
|
||||
assert!(TimeDelta::milliseconds(-1_001) > TimeDelta::milliseconds(-1_002));
|
||||
let milliseconds = |ms| TimeDelta::try_milliseconds(ms).unwrap();
|
||||
|
||||
assert!(milliseconds(1) < milliseconds(2));
|
||||
assert!(milliseconds(2) > milliseconds(1));
|
||||
assert!(milliseconds(-1) > milliseconds(-2));
|
||||
assert!(milliseconds(-2) < milliseconds(-1));
|
||||
assert!(milliseconds(-1) < milliseconds(1));
|
||||
assert!(milliseconds(1) > milliseconds(-1));
|
||||
assert!(milliseconds(0) < milliseconds(1));
|
||||
assert!(milliseconds(0) > milliseconds(-1));
|
||||
assert!(milliseconds(1_001) < milliseconds(1_002));
|
||||
assert!(milliseconds(-1_001) > milliseconds(-1_002));
|
||||
assert!(TimeDelta::nanoseconds(1_234_567_890) < TimeDelta::nanoseconds(1_234_567_891));
|
||||
assert!(TimeDelta::nanoseconds(-1_234_567_890) > TimeDelta::nanoseconds(-1_234_567_891));
|
||||
assert!(TimeDelta::milliseconds(i64::MAX) > TimeDelta::milliseconds(i64::MAX - 1));
|
||||
assert!(TimeDelta::milliseconds(-i64::MAX) < TimeDelta::milliseconds(-i64::MAX + 1));
|
||||
assert!(milliseconds(i64::MAX) > milliseconds(i64::MAX - 1));
|
||||
assert!(milliseconds(-i64::MAX) < milliseconds(-i64::MAX + 1));
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_duration_checked_ops() {
|
||||
assert_eq!(
|
||||
TimeDelta::milliseconds(i64::MAX).checked_add(&TimeDelta::milliseconds(0)),
|
||||
Some(TimeDelta::milliseconds(i64::MAX))
|
||||
);
|
||||
assert_eq!(
|
||||
TimeDelta::milliseconds(i64::MAX - 1).checked_add(&TimeDelta::microseconds(999)),
|
||||
Some(TimeDelta::milliseconds(i64::MAX - 2) + TimeDelta::microseconds(1999))
|
||||
);
|
||||
assert!(TimeDelta::milliseconds(i64::MAX)
|
||||
.checked_add(&TimeDelta::microseconds(1000))
|
||||
.is_none());
|
||||
assert!(TimeDelta::milliseconds(i64::MAX)
|
||||
.checked_add(&TimeDelta::nanoseconds(1))
|
||||
.is_none());
|
||||
let milliseconds = |ms| TimeDelta::try_milliseconds(ms).unwrap();
|
||||
|
||||
assert_eq!(
|
||||
TimeDelta::milliseconds(-i64::MAX).checked_sub(&TimeDelta::milliseconds(0)),
|
||||
Some(TimeDelta::milliseconds(-i64::MAX))
|
||||
milliseconds(i64::MAX).checked_add(&milliseconds(0)),
|
||||
Some(milliseconds(i64::MAX))
|
||||
);
|
||||
assert_eq!(
|
||||
TimeDelta::milliseconds(-i64::MAX + 1).checked_sub(&TimeDelta::microseconds(999)),
|
||||
Some(TimeDelta::milliseconds(-i64::MAX + 2) - TimeDelta::microseconds(1999))
|
||||
milliseconds(i64::MAX - 1).checked_add(&TimeDelta::microseconds(999)),
|
||||
Some(milliseconds(i64::MAX - 2) + TimeDelta::microseconds(1999))
|
||||
);
|
||||
assert!(TimeDelta::milliseconds(-i64::MAX)
|
||||
.checked_sub(&TimeDelta::milliseconds(1))
|
||||
.is_none());
|
||||
assert!(TimeDelta::milliseconds(-i64::MAX)
|
||||
.checked_sub(&TimeDelta::nanoseconds(1))
|
||||
.is_none());
|
||||
assert!(milliseconds(i64::MAX).checked_add(&TimeDelta::microseconds(1000)).is_none());
|
||||
assert!(milliseconds(i64::MAX).checked_add(&TimeDelta::nanoseconds(1)).is_none());
|
||||
|
||||
assert_eq!(
|
||||
milliseconds(-i64::MAX).checked_sub(&milliseconds(0)),
|
||||
Some(milliseconds(-i64::MAX))
|
||||
);
|
||||
assert_eq!(
|
||||
milliseconds(-i64::MAX + 1).checked_sub(&TimeDelta::microseconds(999)),
|
||||
Some(milliseconds(-i64::MAX + 2) - TimeDelta::microseconds(1999))
|
||||
);
|
||||
assert!(milliseconds(-i64::MAX).checked_sub(&milliseconds(1)).is_none());
|
||||
assert!(milliseconds(-i64::MAX).checked_sub(&TimeDelta::nanoseconds(1)).is_none());
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_duration_abs() {
|
||||
assert_eq!(TimeDelta::milliseconds(1300).abs(), TimeDelta::milliseconds(1300));
|
||||
assert_eq!(TimeDelta::milliseconds(1000).abs(), TimeDelta::milliseconds(1000));
|
||||
assert_eq!(TimeDelta::milliseconds(300).abs(), TimeDelta::milliseconds(300));
|
||||
assert_eq!(TimeDelta::milliseconds(0).abs(), TimeDelta::milliseconds(0));
|
||||
assert_eq!(TimeDelta::milliseconds(-300).abs(), TimeDelta::milliseconds(300));
|
||||
assert_eq!(TimeDelta::milliseconds(-700).abs(), TimeDelta::milliseconds(700));
|
||||
assert_eq!(TimeDelta::milliseconds(-1000).abs(), TimeDelta::milliseconds(1000));
|
||||
assert_eq!(TimeDelta::milliseconds(-1300).abs(), TimeDelta::milliseconds(1300));
|
||||
assert_eq!(TimeDelta::milliseconds(-1700).abs(), TimeDelta::milliseconds(1700));
|
||||
assert_eq!(TimeDelta::milliseconds(-i64::MAX).abs(), TimeDelta::milliseconds(i64::MAX));
|
||||
let milliseconds = |ms| TimeDelta::try_milliseconds(ms).unwrap();
|
||||
|
||||
assert_eq!(milliseconds(1300).abs(), milliseconds(1300));
|
||||
assert_eq!(milliseconds(1000).abs(), milliseconds(1000));
|
||||
assert_eq!(milliseconds(300).abs(), milliseconds(300));
|
||||
assert_eq!(milliseconds(0).abs(), milliseconds(0));
|
||||
assert_eq!(milliseconds(-300).abs(), milliseconds(300));
|
||||
assert_eq!(milliseconds(-700).abs(), milliseconds(700));
|
||||
assert_eq!(milliseconds(-1000).abs(), milliseconds(1000));
|
||||
assert_eq!(milliseconds(-1300).abs(), milliseconds(1300));
|
||||
assert_eq!(milliseconds(-1700).abs(), milliseconds(1700));
|
||||
assert_eq!(milliseconds(-i64::MAX).abs(), milliseconds(i64::MAX));
|
||||
}
|
||||
|
||||
#[test]
|
||||
@ -1093,8 +1098,14 @@ mod tests {
|
||||
+ TimeDelta::try_seconds(3).unwrap()
|
||||
+ TimeDelta::try_days(3).unwrap()
|
||||
);
|
||||
assert_eq!(TimeDelta::milliseconds(1500) * -2, TimeDelta::try_seconds(-3).unwrap());
|
||||
assert_eq!(TimeDelta::milliseconds(-1500) * 2, TimeDelta::try_seconds(-3).unwrap());
|
||||
assert_eq!(
|
||||
TimeDelta::try_milliseconds(1500).unwrap() * -2,
|
||||
TimeDelta::try_seconds(-3).unwrap()
|
||||
);
|
||||
assert_eq!(
|
||||
TimeDelta::try_milliseconds(-1500).unwrap() * 2,
|
||||
TimeDelta::try_seconds(-3).unwrap()
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
@ -1107,9 +1118,18 @@ mod tests {
|
||||
assert_eq!(-TimeDelta::nanoseconds(123_456_789) / 1, -TimeDelta::nanoseconds(123_456_789));
|
||||
assert_eq!(TimeDelta::try_seconds(1).unwrap() / 3, TimeDelta::nanoseconds(333_333_333));
|
||||
assert_eq!(TimeDelta::try_seconds(4).unwrap() / 3, TimeDelta::nanoseconds(1_333_333_333));
|
||||
assert_eq!(TimeDelta::try_seconds(-1).unwrap() / 2, TimeDelta::milliseconds(-500));
|
||||
assert_eq!(TimeDelta::try_seconds(1).unwrap() / -2, TimeDelta::milliseconds(-500));
|
||||
assert_eq!(TimeDelta::try_seconds(-1).unwrap() / -2, TimeDelta::milliseconds(500));
|
||||
assert_eq!(
|
||||
TimeDelta::try_seconds(-1).unwrap() / 2,
|
||||
TimeDelta::try_milliseconds(-500).unwrap()
|
||||
);
|
||||
assert_eq!(
|
||||
TimeDelta::try_seconds(1).unwrap() / -2,
|
||||
TimeDelta::try_milliseconds(-500).unwrap()
|
||||
);
|
||||
assert_eq!(
|
||||
TimeDelta::try_seconds(-1).unwrap() / -2,
|
||||
TimeDelta::try_milliseconds(500).unwrap()
|
||||
);
|
||||
assert_eq!(TimeDelta::try_seconds(-4).unwrap() / 3, TimeDelta::nanoseconds(-1_333_333_333));
|
||||
assert_eq!(TimeDelta::try_seconds(-4).unwrap() / -3, TimeDelta::nanoseconds(1_333_333_333));
|
||||
}
|
||||
@ -1145,11 +1165,12 @@ mod tests {
|
||||
assert_eq!(TimeDelta::try_days(42).unwrap().to_string(), "PT3628800S");
|
||||
assert_eq!(TimeDelta::try_days(-42).unwrap().to_string(), "-PT3628800S");
|
||||
assert_eq!(TimeDelta::try_seconds(42).unwrap().to_string(), "PT42S");
|
||||
assert_eq!(TimeDelta::milliseconds(42).to_string(), "PT0.042S");
|
||||
assert_eq!(TimeDelta::try_milliseconds(42).unwrap().to_string(), "PT0.042S");
|
||||
assert_eq!(TimeDelta::microseconds(42).to_string(), "PT0.000042S");
|
||||
assert_eq!(TimeDelta::nanoseconds(42).to_string(), "PT0.000000042S");
|
||||
assert_eq!(
|
||||
(TimeDelta::try_days(7).unwrap() + TimeDelta::milliseconds(6543)).to_string(),
|
||||
(TimeDelta::try_days(7).unwrap() + TimeDelta::try_milliseconds(6543).unwrap())
|
||||
.to_string(),
|
||||
"PT604806.543S"
|
||||
);
|
||||
assert_eq!(TimeDelta::try_seconds(-86_401).unwrap().to_string(), "-PT86401S");
|
||||
@ -1157,7 +1178,10 @@ mod tests {
|
||||
|
||||
// the format specifier should have no effect on `TimeDelta`
|
||||
assert_eq!(
|
||||
format!("{:30}", TimeDelta::try_days(1).unwrap() + TimeDelta::milliseconds(2345)),
|
||||
format!(
|
||||
"{:30}",
|
||||
TimeDelta::try_days(1).unwrap() + TimeDelta::try_milliseconds(2345).unwrap()
|
||||
),
|
||||
"PT86402.345S"
|
||||
);
|
||||
}
|
||||
@ -1166,12 +1190,18 @@ mod tests {
|
||||
fn test_to_std() {
|
||||
assert_eq!(TimeDelta::try_seconds(1).unwrap().to_std(), Ok(Duration::new(1, 0)));
|
||||
assert_eq!(TimeDelta::try_seconds(86_401).unwrap().to_std(), Ok(Duration::new(86_401, 0)));
|
||||
assert_eq!(TimeDelta::milliseconds(123).to_std(), Ok(Duration::new(0, 123_000_000)));
|
||||
assert_eq!(TimeDelta::milliseconds(123_765).to_std(), Ok(Duration::new(123, 765_000_000)));
|
||||
assert_eq!(
|
||||
TimeDelta::try_milliseconds(123).unwrap().to_std(),
|
||||
Ok(Duration::new(0, 123_000_000))
|
||||
);
|
||||
assert_eq!(
|
||||
TimeDelta::try_milliseconds(123_765).unwrap().to_std(),
|
||||
Ok(Duration::new(123, 765_000_000))
|
||||
);
|
||||
assert_eq!(TimeDelta::nanoseconds(777).to_std(), Ok(Duration::new(0, 777)));
|
||||
assert_eq!(MAX.to_std(), Ok(Duration::new(9_223_372_036_854_775, 807_000_000)));
|
||||
assert_eq!(TimeDelta::try_seconds(-1).unwrap().to_std(), Err(OutOfRangeError(())));
|
||||
assert_eq!(TimeDelta::milliseconds(-1).to_std(), Err(OutOfRangeError(())));
|
||||
assert_eq!(TimeDelta::try_milliseconds(-1).unwrap().to_std(), Err(OutOfRangeError(())));
|
||||
}
|
||||
|
||||
#[test]
|
||||
@ -1185,11 +1215,11 @@ mod tests {
|
||||
TimeDelta::from_std(Duration::new(86_401, 0))
|
||||
);
|
||||
assert_eq!(
|
||||
Ok(TimeDelta::milliseconds(123)),
|
||||
Ok(TimeDelta::try_milliseconds(123).unwrap()),
|
||||
TimeDelta::from_std(Duration::new(0, 123_000_000))
|
||||
);
|
||||
assert_eq!(
|
||||
Ok(TimeDelta::milliseconds(123_765)),
|
||||
Ok(TimeDelta::try_milliseconds(123_765).unwrap()),
|
||||
TimeDelta::from_std(Duration::new(123, 765_000_000))
|
||||
);
|
||||
assert_eq!(Ok(TimeDelta::nanoseconds(777)), TimeDelta::from_std(Duration::new(0, 777)));
|
||||
@ -1211,7 +1241,7 @@ mod tests {
|
||||
const ONE_HOUR: TimeDelta = expect!(TimeDelta::try_hours(1), "");
|
||||
const ONE_MINUTE: TimeDelta = expect!(TimeDelta::try_minutes(1), "");
|
||||
const ONE_SECOND: TimeDelta = expect!(TimeDelta::try_seconds(1), "");
|
||||
const ONE_MILLI: TimeDelta = TimeDelta::milliseconds(1);
|
||||
const ONE_MILLI: TimeDelta = expect!(TimeDelta::try_milliseconds(1), "");
|
||||
const ONE_MICRO: TimeDelta = TimeDelta::microseconds(1);
|
||||
const ONE_NANO: TimeDelta = TimeDelta::nanoseconds(1);
|
||||
let combo: TimeDelta = ONE_WEEK
|
||||
|
Loading…
x
Reference in New Issue
Block a user