2015-11-08 14:30:28 +02:00
|
|
|
require_relative "helper"
|
|
|
|
|
2017-01-19 09:02:29 +02:00
|
|
|
module Risc
|
2018-03-30 17:09:02 +03:00
|
|
|
class InterpreterPlusTest < MiniTest::Test
|
2017-01-03 22:42:40 +02:00
|
|
|
include Ticker
|
2015-11-08 14:30:28 +02:00
|
|
|
|
2017-01-03 22:42:40 +02:00
|
|
|
def setup
|
2018-04-01 14:01:17 +03:00
|
|
|
@string_input = as_main("return 5 + 5")
|
2017-01-03 22:42:40 +02:00
|
|
|
super
|
|
|
|
end
|
2015-11-08 14:30:28 +02:00
|
|
|
|
2018-03-31 20:21:27 +03:00
|
|
|
def test_add
|
2018-04-04 20:05:09 +03:00
|
|
|
#show_main_ticks # get output of what is
|
2018-04-07 18:58:44 +03:00
|
|
|
check_main_chain [Label, LoadConstant, LoadConstant, SlotToReg, RegToSlot,
|
|
|
|
RegToSlot, SlotToReg, SlotToReg, RegToSlot, SlotToReg,
|
|
|
|
SlotToReg, RegToSlot, SlotToReg, RegToSlot, SlotToReg,
|
|
|
|
RegToSlot, LoadConstant, SlotToReg, RegToSlot, LoadConstant,
|
|
|
|
SlotToReg, SlotToReg, RegToSlot, LoadConstant, SlotToReg,
|
|
|
|
RegToSlot, SlotToReg, LoadConstant, FunctionCall, Label,
|
|
|
|
SlotToReg, SlotToReg, SlotToReg, SlotToReg, SlotToReg,
|
|
|
|
OperatorInstruction, LoadConstant, SlotToReg, SlotToReg, RegToSlot,
|
|
|
|
RegToSlot, RegToSlot, SlotToReg, SlotToReg, RegToSlot,
|
|
|
|
SlotToReg, SlotToReg, FunctionReturn, SlotToReg, SlotToReg,
|
|
|
|
RegToSlot, SlotToReg, SlotToReg, RegToSlot, SlotToReg,
|
|
|
|
SlotToReg, RegToSlot, SlotToReg, SlotToReg, FunctionReturn,
|
|
|
|
Transfer, Syscall, NilClass]
|
2018-03-31 20:21:27 +03:00
|
|
|
assert_equal Parfait::Integer , get_return.class
|
2018-04-01 12:00:59 +03:00
|
|
|
assert_equal 10 , get_return.value
|
2017-01-03 22:42:40 +02:00
|
|
|
end
|
2018-03-31 19:37:24 +03:00
|
|
|
def test_load_5
|
2018-04-07 18:58:44 +03:00
|
|
|
lod = main_ticks( 20 )
|
2018-03-31 19:37:24 +03:00
|
|
|
assert_equal LoadConstant , lod.class
|
|
|
|
assert_equal Parfait::Integer , lod.constant.class
|
|
|
|
assert_equal 5 , lod.constant.value
|
|
|
|
end
|
|
|
|
def test_slot_receiver #load receiver from message
|
2018-04-07 18:58:44 +03:00
|
|
|
sl = main_ticks( 31 )
|
2018-03-30 18:05:38 +03:00
|
|
|
assert_equal SlotToReg , sl.class
|
2018-03-31 19:37:24 +03:00
|
|
|
assert_equal :r0 , sl.array.symbol #load from message
|
|
|
|
assert_equal 3 , sl.index
|
|
|
|
assert_equal :r1 , sl.register.symbol
|
2018-03-30 18:05:38 +03:00
|
|
|
end
|
2018-03-31 19:37:24 +03:00
|
|
|
def test_slot_args #load args from message
|
2018-04-07 18:58:44 +03:00
|
|
|
sl = main_ticks( 32 )
|
2018-03-30 18:05:38 +03:00
|
|
|
assert_equal SlotToReg , sl.class
|
2018-03-31 19:37:24 +03:00
|
|
|
assert_equal :r0 , sl.array.symbol #load from message
|
2018-03-30 18:05:38 +03:00
|
|
|
assert_equal 9 , sl.index
|
2018-03-31 19:37:24 +03:00
|
|
|
assert_equal :r2 , sl.register.symbol
|
2018-03-30 18:05:38 +03:00
|
|
|
end
|
2018-03-31 19:37:24 +03:00
|
|
|
def test_slot_arg #load arg 1, destructively from args
|
2018-04-07 18:58:44 +03:00
|
|
|
sl = main_ticks( 33 )
|
2018-03-30 18:05:38 +03:00
|
|
|
assert_equal SlotToReg , sl.class
|
2018-03-31 19:37:24 +03:00
|
|
|
assert_equal :r2 , sl.array.symbol #load from message
|
2018-03-30 18:05:38 +03:00
|
|
|
assert_equal 2 , sl.index
|
|
|
|
assert_equal :r2 , sl.register.symbol
|
|
|
|
end
|
2018-03-31 19:37:24 +03:00
|
|
|
def test_slot_int1 #load int from object
|
2018-04-07 18:58:44 +03:00
|
|
|
sl = main_ticks( 34 )
|
2018-03-31 19:37:24 +03:00
|
|
|
assert_equal SlotToReg , sl.class
|
|
|
|
assert_equal :r1 , sl.array.symbol #load from message
|
|
|
|
assert_equal 3 , sl.index
|
|
|
|
assert_equal :r1 , sl.register.symbol
|
2017-01-03 22:42:40 +02:00
|
|
|
end
|
2018-03-31 19:37:24 +03:00
|
|
|
def test_op
|
2018-04-07 18:58:44 +03:00
|
|
|
op = main_ticks(36)
|
2018-03-31 19:37:24 +03:00
|
|
|
assert_equal OperatorInstruction , op.class
|
|
|
|
assert_equal :r1 , op.left.symbol
|
|
|
|
assert_equal :r2 , op.right.symbol
|
|
|
|
assert_equal 5 , @interpreter.get_register(:r2)
|
|
|
|
assert_equal 10 , @interpreter.get_register(:r1)
|
2017-01-03 22:42:40 +02:00
|
|
|
end
|
2018-04-01 12:00:59 +03:00
|
|
|
def test_load_int_space
|
2018-04-07 18:58:44 +03:00
|
|
|
cons = main_ticks(37)
|
2018-04-01 12:00:59 +03:00
|
|
|
assert_equal LoadConstant , cons.class
|
|
|
|
assert_equal Parfait::Space , cons.constant.class
|
|
|
|
assert_equal :r3 , cons.register.symbol
|
|
|
|
end
|
|
|
|
def test_load_int_next_space
|
2018-04-07 18:58:44 +03:00
|
|
|
sl = main_ticks(38)
|
2018-04-01 12:00:59 +03:00
|
|
|
assert_equal SlotToReg , sl.class
|
|
|
|
assert_equal :r3 , sl.array.symbol #load from space
|
|
|
|
assert_equal 5 , sl.index
|
|
|
|
assert_equal :r2 , sl.register.symbol
|
|
|
|
assert_equal Parfait::Integer , @interpreter.get_register(:r2).class
|
|
|
|
end
|
|
|
|
def test_load_int_next_int
|
2018-04-07 18:58:44 +03:00
|
|
|
sl = main_ticks(39)
|
2018-04-01 12:00:59 +03:00
|
|
|
assert_equal SlotToReg , sl.class
|
|
|
|
assert_equal :r2 , sl.array.symbol #load from next_int
|
|
|
|
assert_equal 2 , sl.index
|
|
|
|
assert_equal :r4 , sl.register.symbol
|
|
|
|
assert_equal Parfait::Integer , @interpreter.get_register(:r4).class
|
|
|
|
end
|
|
|
|
def test_load_int_next_int2
|
2018-04-07 18:58:44 +03:00
|
|
|
sl = main_ticks(40)
|
2018-04-01 12:00:59 +03:00
|
|
|
assert_equal RegToSlot , sl.class
|
|
|
|
assert_equal :r3 , sl.array.symbol #store to space
|
|
|
|
assert_equal 5 , sl.index
|
|
|
|
assert_equal :r4 , sl.register.symbol
|
|
|
|
end
|
2018-04-01 14:56:01 +03:00
|
|
|
def test_sys
|
2018-04-07 18:58:44 +03:00
|
|
|
sys = main_ticks(62)
|
2018-04-01 14:56:01 +03:00
|
|
|
assert_equal Syscall , sys.class
|
|
|
|
assert_equal :exit , sys.name
|
|
|
|
end
|
2015-11-08 15:15:55 +02:00
|
|
|
end
|
2015-11-08 14:30:28 +02:00
|
|
|
end
|