ganit-core 0.3.4

Spreadsheet formula engine — parser and evaluator for Excel-compatible formulas
Documentation
use super::super::yearfrac_fn;
use crate::types::{ErrorKind, Value};

#[test]
fn no_args_returns_na() {
    assert_eq!(yearfrac_fn(&[]), Value::Error(ErrorKind::NA));
}

#[test]
fn one_arg_returns_na() {
    assert_eq!(yearfrac_fn(&[Value::Number(45292.0)]), Value::Error(ErrorKind::NA));
}

#[test]
fn too_many_args_returns_na() {
    let args = [
        Value::Number(45292.0), Value::Number(45658.0),
        Value::Number(0.0), Value::Number(0.0),
    ];
    assert_eq!(yearfrac_fn(&args), Value::Error(ErrorKind::NA));
}

#[test]
fn non_numeric_start_returns_value_error() {
    let args = [Value::Text("bad".to_string()), Value::Number(45658.0)];
    assert_eq!(yearfrac_fn(&args), Value::Error(ErrorKind::Value));
}

#[test]
fn invalid_basis_5_returns_num_error() {
    let args = [Value::Number(45292.0), Value::Number(45658.0), Value::Number(5.0)];
    assert_eq!(yearfrac_fn(&args), Value::Error(ErrorKind::Num));
}