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 zero_initial_cash_flow() {
let args = [Value::Number(0.0), Value::Number(-100.0), Value::Number(150.0)];
assert!(matches!(irr_fn(&args), Value::Number(_)));
}
#[test]
fn large_series() {
let mut args = vec![Value::Number(-1000.0)];
for _ in 0..10 {
args.push(Value::Number(150.0));
}
let result = irr_fn(&args);
assert!(approx(result, 0.0814, 0.001));
}
#[test]
fn exact_zero_irr() {
let args = [Value::Number(-100.0), Value::Number(100.0)];
assert!(approx(irr_fn(&args), 0.0, 1e-6));
}