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_weibull_dist_smoke() {
    let mut model = new_empty_model();

    // Valid: CDF and PDF for x = 1, alpha = 2, beta = 1
    model._set("A1", "=WEIBULL.DIST(1, 2, 1, TRUE)");
    model._set("A2", "=WEIBULL.DIST(1, 2, 1, FALSE)");

    // Wrong number of arguments -> #ERROR!
    model._set("A3", "=WEIBULL.DIST(1, 2, 1)");
    model._set("A4", "=WEIBULL.DIST(1, 2, 1, TRUE, FALSE)");

    // Domain errors:
    // x < 0  -> #NUM!
    model._set("A5", "=WEIBULL.DIST(-1, 2, 1, TRUE)");
    // alpha <= 0 -> #NUM!
    model._set("A6", "=WEIBULL.DIST(1, 0, 1, TRUE)");
    model._set("A7", "=WEIBULL.DIST(1, -1, 1, TRUE)");
    // beta <= 0 -> #NUM!
    model._set("A8", "=WEIBULL.DIST(1, 2, 0, TRUE)");
    model._set("A9", "=WEIBULL.DIST(1, 2, -1, TRUE)");

    model.evaluate();

    // 1 - e^-1
    assert_eq!(model._get_text("A1"), *"0.632120559");
    // 2 * e^-1
    assert_eq!(model._get_text("A2"), *"0.735758882");

    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!");
    assert_eq!(model._get_text("A7"), *"#NUM!");
    assert_eq!(model._get_text("A8"), *"#NUM!");
    assert_eq!(model._get_text("A9"), *"#NUM!");
}