hifitime 3.8.0

Ultra-precise date and time handling in Rust for scientific applications with leap second support
Documentation
extern crate hifitime;
use hifitime::{Errors, ParsingErrors, TimeScale};
use std::str::FromStr;

#[test]
fn test_from_str() {
    let values = vec![
        ("TAI", TimeScale::TAI),
        ("UTC", TimeScale::UTC),
        ("TT", TimeScale::TT),
        ("TDB", TimeScale::TDB),
        ("GPST", TimeScale::GPST),
        ("GST", TimeScale::GST),
        ("BDT", TimeScale::BDT),
    ];
    for value in values {
        let (descriptor, expected) = value;
        let ts = TimeScale::from_str(descriptor);
        assert_eq!(ts.is_ok(), true);
        let ts = ts.unwrap();
        assert_eq!(ts, expected);
        // test to_str()/format()
        assert_eq!(format!("{}", ts), descriptor);
        // test format(0x)
        let expected: &str = match ts {
            TimeScale::GPST => "GPS",
            TimeScale::GST => "GAL",
            TimeScale::BDT => "BDS",
            _ => descriptor, // untouched
        };
        assert_eq!(format!("{:x}", ts), expected);
    }
}

#[test]
fn test_from_rinex_format() {
    /*
     * Test (GNSS) timescales identification
     * from standard 3 letter constellation code
     */
    assert_eq!(TimeScale::from_str("GPS"), Ok(TimeScale::GPST));
    assert_eq!(TimeScale::from_str("GAL"), Ok(TimeScale::GST));
    assert_eq!(TimeScale::from_str("BDS"), Ok(TimeScale::BDT));
    // Check error
    assert_eq!(
        TimeScale::from_str("FAK"),
        Err(Errors::ParseError(ParsingErrors::TimeSystem))
    );
}

#[test]
fn test_is_gnss() {
    let ts = TimeScale::GPST;
    assert!(ts.is_gnss());
    let ts = TimeScale::GST;
    assert!(ts.is_gnss());
    let ts = TimeScale::UTC;
    assert!(!ts.is_gnss());
    let ts = TimeScale::TAI;
    assert!(!ts.is_gnss());
}

#[test]
fn test_default() {
    assert_eq!(TimeScale::default(), TimeScale::TAI);
}