use jiff::civil;
use super::compute;
use crate::error::Error;
pub fn year(today: civil::Date) -> Result<f64, Error> {
year_ratio(today)
}
fn year_ratio(today: civil::Date) -> Result<f64, Error> {
let start = civil::date(today.year(), 1, 1);
let end = civil::date(today.year() + 1, 1, 1);
compute(today, start, end)
}
#[cfg(test)]
mod tests {
use jiff::civil;
use super::*;
use anyhow::Result;
#[test]
fn year_should_be_0() -> Result<()> {
let current = civil::date(2021, 1, 1);
let ratio = year_ratio(current)?;
let ratio_int = (ratio * 100.0) as i32;
assert_eq!(ratio, 0.0);
assert_eq!(ratio_int, 0);
let current = civil::date(2022, 1, 1);
let ratio = year_ratio(current)?;
let ratio_int = (ratio * 100.0) as i32;
assert_eq!(ratio, 0.0);
assert_eq!(ratio_int, 0);
let current = civil::date(2023, 1, 1);
let ratio = year_ratio(current)?;
let ratio_int = (ratio * 100.0) as i32;
assert_eq!(ratio, 0.0);
assert_eq!(ratio_int, 0);
Ok(())
}
#[test]
fn year_should_be_50() -> Result<()> {
let current = civil::date(2021, 7, 4);
let ratio = year_ratio(current)?;
let ratio_int = (ratio * 100.0) as i32;
assert_eq!(ratio, 0.5041095890410959);
assert_eq!(ratio_int, 50);
let current = civil::date(2022, 7, 3);
let ratio = year_ratio(current)?;
let ratio_int = (ratio * 100.0) as i32;
assert_eq!(ratio, 0.5013698630136987);
assert_eq!(ratio_int, 50);
let current = civil::date(2023, 7, 3);
let ratio = year_ratio(current)?;
let ratio_int = (ratio * 100.0) as i32;
assert_eq!(ratio, 0.5013698630136987);
assert_eq!(ratio_int, 50);
Ok(())
}
#[test]
fn year_should_be_100() -> Result<()> {
let current = civil::date(2021, 12, 31);
let ratio = year_ratio(current)?;
let ratio_int = (ratio * 100.0) as i32;
assert_eq!(ratio, 0.9972602739726028);
assert_eq!(ratio_int, 99);
let current = civil::date(2023, 12, 31);
let ratio = year_ratio(current)?;
let ratio_int = (ratio * 100.0) as i32;
assert_eq!(ratio, 0.9972602739726028);
assert_eq!(ratio_int, 99);
let current = civil::date(2023, 12, 31);
let ratio = year_ratio(current)?;
let ratio_int = (ratio * 100.0) as i32;
assert_eq!(ratio, 0.9972602739726028);
assert_eq!(ratio_int, 99);
Ok(())
}
}