std::time::Duration -> base::Duration conversion

This commit is contained in:
Scott Lamb 2021-04-22 09:56:01 -07:00
parent 1e314e09d0
commit d99cab5f27

View File

@ -289,6 +289,14 @@ impl fmt::Display for Duration {
} }
} }
impl std::convert::TryFrom<std::time::Duration> for Duration {
type Error = std::num::TryFromIntError;
fn try_from(value: std::time::Duration) -> Result<Self, Self::Error> {
Ok(Self(i64::try_from(value.as_nanos() * 9 / 100_000)?))
}
}
impl ops::Mul<i64> for Duration { impl ops::Mul<i64> for Duration {
type Output = Self; type Output = Self;
fn mul(self, rhs: i64) -> Self::Output { fn mul(self, rhs: i64) -> Self::Output {
@ -318,6 +326,7 @@ impl ops::SubAssign for Duration {
#[cfg(test)] #[cfg(test)]
mod tests { mod tests {
use super::{Duration, Time, TIME_UNITS_PER_SEC}; use super::{Duration, Time, TIME_UNITS_PER_SEC};
use std::convert::TryFrom;
#[test] #[test]
fn test_parse_time() { fn test_parse_time() {
@ -373,4 +382,21 @@ mod tests {
assert_eq!(test.0, format!("{}", Duration(test.1 * TIME_UNITS_PER_SEC))); assert_eq!(test.0, format!("{}", Duration(test.1 * TIME_UNITS_PER_SEC)));
} }
} }
#[test]
fn test_duration_from_std_duration() {
assert_eq!(
Duration::try_from(std::time::Duration::new(1, 11111)),
Ok(Duration(90_000))
);
assert_eq!(
Duration::try_from(std::time::Duration::new(1, 11112)),
Ok(Duration(90_001))
);
assert_eq!(
Duration::try_from(std::time::Duration::new(60, 0)),
Ok(Duration(60 * TIME_UNITS_PER_SEC))
);
Duration::try_from(std::time::Duration::new(u64::MAX, 0)).unwrap_err();
}
} }