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 smoke_test() {
    let code = "def add(a, b)
        a + b
    end";
    let binary = mrbc_compile("add", code);
    let mut rite = mrubyedge::rite::load(&binary).unwrap();
    let mut vm = mrubyedge::yamrb::vm::VM::open(&mut rite);
    vm.run().unwrap();

    // Assert
    let args = vec![int(1), int(2)];
    let result: i32 = mrb_funcall(&mut vm, None, "add", &args)
        .unwrap()
        .as_ref()
        .try_into()
        .unwrap();
    assert_eq!(result, 3);
}

#[test]
fn p_test() {
    let code = "
    def hello
      o = Object.new
      p o
    end";
    let binary = mrbc_compile("ppp", code);
    let mut rite = mrubyedge::rite::load(&binary).unwrap();
    let mut vm = mrubyedge::yamrb::vm::VM::open(&mut rite);
    vm.run().unwrap();

    // Assert
    let args = vec![];
    let result: () = mrb_funcall(&mut vm, None, "hello", &args)
        .unwrap()
        .as_ref()
        .try_into()
        .unwrap();
    assert_eq!(result, ());
}

#[test]
fn fib_test() {
    let code = "
        def fib(n)
          if n < 1
            return 0
          elsif n < 3
            return 1
          else
            return fib(n-1)+fib(n-2)
          end
        end
    ";
    let binary = mrbc_compile("fib1", code);
    let mut rite = mrubyedge::rite::load(&binary).unwrap();
    let mut vm = mrubyedge::yamrb::vm::VM::open(&mut rite);
    vm.run().unwrap();

    // Assert
    let args = vec![int(1)];
    let result: i32 = mrb_funcall(&mut vm, None, "fib", &args)
        .unwrap()
        .as_ref()
        .try_into()
        .unwrap();
    assert_eq!(result, 1);

    let args = vec![int(2)];
    let result: i32 = mrb_funcall(&mut vm, None, "fib", &args)
        .unwrap()
        .as_ref()
        .try_into()
        .unwrap();
    assert_eq!(result, 1);

    let args = vec![int(3)];
    let result: i32 = mrb_funcall(&mut vm, None, "fib", &args)
        .unwrap()
        .as_ref()
        .try_into()
        .unwrap();
    assert_eq!(result, 2);

    let args = vec![int(10)];
    let result: i32 = mrb_funcall(&mut vm, None, "fib", &args)
        .unwrap()
        .as_ref()
        .try_into()
        .unwrap();
    assert_eq!(result, 55);

    let args = vec![int(15)];
    let result: i32 = mrb_funcall(&mut vm, None, "fib", &args)
        .unwrap()
        .as_ref()
        .try_into()
        .unwrap();
    assert_eq!(result, 610);
}

#[test]
fn fib2_test() {
    let code = "
        def fib(n)
          case n
          when 0
            0
          when 1..2
            1
          else
            fib(n - 1) + fib(n - 2)
          end
        end
    ";
    let binary = mrbc_compile("fib2", code);
    let mut rite = mrubyedge::rite::load(&binary).unwrap();
    let mut vm = mrubyedge::yamrb::vm::VM::open(&mut rite);
    vm.run().unwrap();

    // Assert
    let args = vec![int(1)];
    let result: i32 = mrb_funcall(&mut vm, None, "fib", &args)
        .unwrap()
        .as_ref()
        .try_into()
        .unwrap();
    assert_eq!(result, 1);

    let args = vec![int(2)];
    let result: i32 = mrb_funcall(&mut vm, None, "fib", &args)
        .unwrap()
        .as_ref()
        .try_into()
        .unwrap();
    assert_eq!(result, 1);

    let args = vec![int(3)];
    let result: i32 = mrb_funcall(&mut vm, None, "fib", &args)
        .unwrap()
        .as_ref()
        .try_into()
        .unwrap();
    assert_eq!(result, 2);

    let args = vec![int(10)];
    let result: i32 = mrb_funcall(&mut vm, None, "fib", &args)
        .unwrap()
        .as_ref()
        .try_into()
        .unwrap();
    assert_eq!(result, 55);

    let args = vec![int(15)];
    let result: i32 = mrb_funcall(&mut vm, None, "fib", &args)
        .unwrap()
        .as_ref()
        .try_into()
        .unwrap();
    assert_eq!(result, 610);
}