use super::super::*;
use crate::types::Value;
fn approx(a: Value, b: f64, tol: f64) -> bool {
if let Value::Number(n) = a { (n - b).abs() < tol } else { false }
}
#[test]
fn custom_guess() {
let args = [
Value::Number(60.0),
Value::Number(-188.71),
Value::Number(10000.0),
Value::Number(0.0),
Value::Number(0.0),
Value::Number(0.004), ];
assert!(approx(rate_fn(&args), 0.05 / 12.0, 0.0001));
}
#[test]
fn type1_rate() {
let args = [
Value::Number(5.0),
Value::Number(-250.0),
Value::Number(1000.0),
Value::Number(0.0),
Value::Number(1.0),
];
let result = rate_fn(&args);
assert!(matches!(result, Value::Number(_)));
}
#[test]
fn fv_non_zero() {
let args = [
Value::Number(10.0),
Value::Number(-100.0),
Value::Number(500.0),
Value::Number(200.0),
];
let result = rate_fn(&args);
assert!(matches!(result, Value::Number(_)));
}
#[test]
fn guess_zero_forces_r0_branch() {
let args = [
Value::Number(60.0),
Value::Number(-188.71),
Value::Number(10000.0),
Value::Number(0.0),
Value::Number(0.0),
Value::Number(0.0),
];
assert!(approx(rate_fn(&args), 0.05 / 12.0, 1e-4));
}