extern crate mec_mrbc_sys;
extern crate mrubyedge;
mod helpers;
use std::rc::Rc;
use helpers::*;
use mrubyedge::RObject;
#[test]
fn float_clamp_test() {
let code = "
result1 = 100.5.clamp(50.0, 150.0)
result2 = 25.5.clamp(50.0, 150.0)
result3 = 200.5.clamp(50.0, 150.0)
result1 + result2 + result3
";
let binary = mrbc_compile("float_clamp", code);
let mut rite = mrubyedge::rite::load(&binary).unwrap();
let mut vm = mrubyedge::yamrb::vm::VM::open(&mut rite);
let result = vm.run().unwrap();
let result_float: f64 = result.as_ref().try_into().unwrap();
assert_eq!(result_float, 300.5); }
#[test]
fn float_clamp_with_integer_bounds_test() {
let code = "
result1 = 100.5.clamp(50, 150)
result2 = 25.5.clamp(50, 150)
result3 = 200.5.clamp(50, 150)
result1 + result2 + result3
";
let binary = mrbc_compile("float_clamp_int", code);
let mut rite = mrubyedge::rite::load(&binary).unwrap();
let mut vm = mrubyedge::yamrb::vm::VM::open(&mut rite);
let result = vm.run().unwrap();
let result_float: f64 = result.as_ref().try_into().unwrap();
assert_eq!(result_float, 300.5); }
#[test]
fn float_add_method_test() {
let code = r#"
def test_add
a = 5.5
b = 3.2
a.+(b)
end
"#;
let binary = mrbc_compile("float_add_method", code);
let mut rite = mrubyedge::rite::load(&binary).unwrap();
let mut vm = mrubyedge::yamrb::vm::VM::open(&mut rite);
vm.run().unwrap();
let args = vec![];
let result = mrb_funcall(&mut vm, None, "test_add", &args).unwrap();
let result_float: f64 = result.as_ref().try_into().unwrap();
assert_eq!(result_float, 8.7);
}
#[test]
fn float_sub_method_test() {
let code = r#"
def test_sub
a = 10.5
b = 3.2
a.-(b)
end
"#;
let binary = mrbc_compile("float_sub_method", code);
let mut rite = mrubyedge::rite::load(&binary).unwrap();
let mut vm = mrubyedge::yamrb::vm::VM::open(&mut rite);
vm.run().unwrap();
let args = vec![];
let result = mrb_funcall(&mut vm, None, "test_sub", &args).unwrap();
let result_float: f64 = result.as_ref().try_into().unwrap();
assert!((result_float - 7.3).abs() < 0.0001); }
#[test]
fn float_add_integer_test() {
let code = r#"
def test_add_int
a = 5.5
i = 3
a.+(i)
end
"#;
let binary = mrbc_compile("float_add_int", code);
let mut rite = mrubyedge::rite::load(&binary).unwrap();
let mut vm = mrubyedge::yamrb::vm::VM::open(&mut rite);
vm.run().unwrap();
let args = vec![];
let result = mrb_funcall(&mut vm, None, "test_add_int", &args).unwrap();
let result_float: f64 = result.as_ref().try_into().unwrap();
assert_eq!(result_float, 8.5);
}
#[test]
fn float_infinite_test() {
let code = r#"
def test_infinite
value = 1.0 / 0.0
value.infinite?
end
"#;
let binary = mrbc_compile("float_infinite", code);
let mut rite = mrubyedge::rite::load(&binary).unwrap();
let mut vm = mrubyedge::yamrb::vm::VM::open(&mut rite);
vm.run().unwrap();
let args = vec![];
let result = mrb_funcall(&mut vm, None, "test_infinite", &args).unwrap();
let infinite: bool = result.as_ref().try_into().unwrap();
assert!(infinite);
}
#[test]
fn float_finite_test() {
let code = r#"
def test_finite
value = 1.0 / 1.0
value.finite?
end
"#;
let binary = mrbc_compile("float_finite", code);
let mut rite = mrubyedge::rite::load(&binary).unwrap();
let mut vm = mrubyedge::yamrb::vm::VM::open(&mut rite);
vm.run().unwrap();
let args = vec![];
let result = mrb_funcall(&mut vm, None, "test_finite", &args).unwrap();
let finite: bool = result.as_ref().try_into().unwrap();
assert!(finite);
}
#[test]
fn float_nan_test() {
let code = r#"
def test_nan
value = 0.0 / 0.0
value.nan?
end
"#;
let binary = mrbc_compile("float_nan", code);
let mut rite = mrubyedge::rite::load(&binary).unwrap();
let mut vm = mrubyedge::yamrb::vm::VM::open(&mut rite);
vm.run().unwrap();
let args = vec![];
let result = mrb_funcall(&mut vm, None, "test_nan", &args).unwrap();
let nan: bool = result.as_ref().try_into().unwrap();
assert!(nan);
}
#[test]
fn float_constants_test() {
let code = r#"
def test_constants
[
Float::INFINITY,
Float::NAN,
Float::EPSILON
]
end
"#;
let binary = mrbc_compile("float_constants", code);
let mut rite = mrubyedge::rite::load(&binary).unwrap();
let mut vm = mrubyedge::yamrb::vm::VM::open(&mut rite);
vm.run().unwrap();
let args = vec![];
let result = mrb_funcall(&mut vm, None, "test_constants", &args).unwrap();
let constants: Vec<Rc<RObject>> = result.as_ref().try_into().unwrap();
let floats: Vec<f64> = constants
.iter()
.map(|c| c.as_ref().try_into().unwrap())
.collect::<Vec<_>>();
assert_eq!(floats[0], f64::INFINITY);
assert!(floats[1].is_nan());
assert_eq!(floats[2], f64::EPSILON);
}