mrubyedge 1.1.12

mruby/edge is yet another mruby that is specialized for running on WASM
Documentation
extern crate mec_mrbc_sys;
extern crate mrubyedge;

mod helpers;
use helpers::*;

#[test]
fn test_float_mul() {
    let code = "
    result = 3.5 * 2.0
    result
    ";
    let binary = mrbc_compile("float_mul", 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 value: f64 = result.as_ref().try_into().unwrap();
    assert_eq!(value, 7.0);
}

#[test]
fn test_float_div() {
    let code = "
    result = 10.0 / 2.0
    result
    ";
    let binary = mrbc_compile("float_div", 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 value: f64 = result.as_ref().try_into().unwrap();
    assert_eq!(value, 5.0);
}

#[test]
fn test_float_positive() {
    let code = "
    result = +3.5
    result
    ";
    let binary = mrbc_compile("float_positive", 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 value: f64 = result.as_ref().try_into().unwrap();
    assert_eq!(value, 3.5);
}

#[test]
fn test_float_negative() {
    let code = "
    result = -3.5
    result
    ";
    let binary = mrbc_compile("float_negative", 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 value: f64 = result.as_ref().try_into().unwrap();
    assert_eq!(value, -3.5);
}

#[test]
fn test_float_power() {
    let code = "
    result = 2.0 ** 3.0
    result
    ";
    let binary = mrbc_compile("float_power", 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 value: f64 = result.as_ref().try_into().unwrap();
    assert_eq!(value, 8.0);
}

#[test]
fn test_float_abs() {
    let code = "
    result = -3.5.abs
    result
    ";
    let binary = mrbc_compile("float_abs", 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 value: f64 = result.as_ref().try_into().unwrap();
    assert_eq!(value, 3.5);
}

#[test]
fn test_float_mul_with_integer() {
    let code = "
    result = 3.5 * 2
    result
    ";
    let binary = mrbc_compile("float_mul_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 value: f64 = result.as_ref().try_into().unwrap();
    assert_eq!(value, 7.0);
}

#[test]
fn test_float_div_with_integer() {
    let code = "
    result = 10.0 / 2
    result
    ";
    let binary = mrbc_compile("float_div_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 value: f64 = result.as_ref().try_into().unwrap();
    assert_eq!(value, 5.0);
}

#[test]
fn test_float_add() {
    let code = "
    result = 3.5 + 2.5
    result
    ";
    let binary = mrbc_compile("float_add", 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 value: f64 = result.as_ref().try_into().unwrap();
    assert_eq!(value, 6.0);
}

#[test]
fn test_float_sub() {
    let code = "
    result = 10.0 - 3.5
    result
    ";
    let binary = mrbc_compile("float_sub", 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 value: f64 = result.as_ref().try_into().unwrap();
    assert_eq!(value, 6.5);
}