ironcalc_base 0.7.1

Open source spreadsheet engine
Documentation
#![allow(clippy::unwrap_used)]

use crate::test::util::new_empty_model;

#[test]
fn test_fn_log_norm_dist_smoke() {
    let mut model = new_empty_model();

    // Valid: CDF and PDF
    model._set("A1", "=LOGNORM.DIST(4, 3.5, 1.2, TRUE)");
    model._set("A2", "=LOGNORM.DIST(4, 3.5, 1.2, FALSE)");

    // Wrong number of arguments -> #ERROR!
    model._set("A3", "=LOGNORM.DIST(4, 3.5, 1.2)");
    model._set("A4", "=LOGNORM.DIST(4, 3.5, 1.2, TRUE, FALSE)");

    // Domain errors:
    // x <= 0 -> #NUM!
    model._set("A5", "=LOGNORM.DIST(0, 3.5, 1.2, TRUE)");
    // std_dev <= 0 -> #NUM!
    model._set("A6", "=LOGNORM.DIST(4, 3.5, 0, TRUE)");

    model.evaluate();

    assert_eq!(model._get_text("A1"), *"0.039083556");
    assert_eq!(model._get_text("A2"), *"0.017617597");

    assert_eq!(model._get_text("A3"), *"#ERROR!");
    assert_eq!(model._get_text("A4"), *"#ERROR!");
    assert_eq!(model._get_text("A5"), *"#NUM!");
    assert_eq!(model._get_text("A6"), *"#NUM!");
}

#[test]
fn test_fn_log_norm_inv_smoke() {
    let mut model = new_empty_model();

    // Valid call
    model._set("A1", "=LOGNORM.INV(0.5, 3.5, 1.2)");

    // Wrong number of arguments -> #ERROR!
    model._set("A2", "=LOGNORM.INV(0.5, 3.5)");
    model._set("A3", "=LOGNORM.INV(0.5, 3.5, 1.2, 0)");

    // Domain errors:
    // probability <= 0 or >= 1 -> #NUM!
    model._set("A4", "=LOGNORM.INV(0, 3.5, 1.2)");
    model._set("A5", "=LOGNORM.INV(1, 3.5, 1.2)");
    // std_dev <= 0 -> #NUM!
    model._set("A6", "=LOGNORM.INV(0.5, 3.5, 0)");

    model.evaluate();

    assert_eq!(model._get_text("A1"), *"33.115451959");

    assert_eq!(model._get_text("A2"), *"#ERROR!");
    assert_eq!(model._get_text("A3"), *"#ERROR!");
    assert_eq!(model._get_text("A4"), *"#NUM!");
    assert_eq!(model._get_text("A5"), *"#NUM!");
    assert_eq!(model._get_text("A6"), *"#NUM!");
}