2018-07-31 18:00:42 +03:00
|
|
|
require_relative "../helper"
|
|
|
|
|
|
|
|
module Risc
|
2018-08-16 08:58:49 +03:00
|
|
|
class BlockAssignOuter < MiniTest::Test
|
2018-07-31 18:00:42 +03:00
|
|
|
include Ticker
|
|
|
|
|
|
|
|
def setup
|
|
|
|
@string_input = block_main("a = 15 ;yielder {a = 10 ; return 15} ; return a")
|
|
|
|
super
|
|
|
|
end
|
|
|
|
|
2018-08-06 14:07:17 +03:00
|
|
|
def test_chain
|
2019-08-22 23:10:29 +03:00
|
|
|
#show_main_ticks # get output of what is
|
2019-08-23 19:25:02 +03:00
|
|
|
check_main_chain [LoadConstant, RegToSlot, LoadConstant, SlotToReg, RegToSlot, #5
|
|
|
|
SlotToReg, SlotToReg, RegToSlot, LoadConstant, SlotToReg, #10
|
|
|
|
RegToSlot, LoadConstant, SlotToReg, RegToSlot, SlotToReg, #15
|
|
|
|
FunctionCall, LoadConstant, SlotToReg, OperatorInstruction, IsZero, #20
|
|
|
|
SlotToReg, SlotToReg, RegToSlot, SlotToReg, SlotToReg, #25
|
|
|
|
RegToSlot, SlotToReg, LoadConstant, RegToSlot, SlotToReg, #30
|
|
|
|
SlotToReg, DynamicJump, LoadConstant, SlotToReg, SlotToReg, #35
|
|
|
|
RegToSlot, LoadConstant, RegToSlot, Branch, SlotToReg, #40
|
|
|
|
SlotToReg, RegToSlot, SlotToReg, SlotToReg, SlotToReg, #45
|
|
|
|
FunctionReturn, SlotToReg, RegToSlot, Branch, SlotToReg, #50
|
|
|
|
SlotToReg, RegToSlot, SlotToReg, SlotToReg, SlotToReg, #55
|
|
|
|
FunctionReturn, SlotToReg, RegToSlot, Branch, SlotToReg, #60
|
|
|
|
SlotToReg, RegToSlot, SlotToReg, SlotToReg, SlotToReg, #65
|
|
|
|
FunctionReturn, Transfer, SlotToReg, SlotToReg, Syscall, #70
|
|
|
|
NilClass,] #75
|
2018-07-31 18:00:42 +03:00
|
|
|
assert_equal 10 , get_return
|
|
|
|
end
|
2019-08-23 19:25:02 +03:00
|
|
|
def base ; 32 ; end
|
2018-07-31 18:00:42 +03:00
|
|
|
|
2018-08-06 14:07:17 +03:00
|
|
|
def test_block_jump
|
2019-08-22 23:10:29 +03:00
|
|
|
load_ins = main_ticks(base)
|
2018-07-31 18:00:42 +03:00
|
|
|
assert_equal DynamicJump , load_ins.class
|
|
|
|
assert_equal Parfait::Block , @interpreter.get_register(load_ins.register).class
|
|
|
|
end
|
2018-08-06 14:07:17 +03:00
|
|
|
def test_block_load
|
2019-08-22 23:10:29 +03:00
|
|
|
load_ins = main_ticks(base+1)
|
2018-07-31 18:00:42 +03:00
|
|
|
assert_load load_ins , Parfait::Integer , :r1
|
|
|
|
assert_equal 10 , @interpreter.get_register(load_ins.register).value
|
|
|
|
end
|
2018-08-06 14:07:17 +03:00
|
|
|
def test_block_slot1
|
2019-08-22 23:10:29 +03:00
|
|
|
assert_slot_to_reg main_ticks(base+2) ,:r0 , 6 , :r2
|
2018-07-31 18:00:42 +03:00
|
|
|
end
|
2018-08-06 14:07:17 +03:00
|
|
|
def test_block_slot2
|
2019-08-22 23:10:29 +03:00
|
|
|
assert_slot_to_reg main_ticks(base+3) ,:r2 , 6 , :r2
|
2018-07-31 18:00:42 +03:00
|
|
|
end
|
2018-08-06 14:07:17 +03:00
|
|
|
def test_block_reg
|
2019-08-23 10:20:39 +03:00
|
|
|
assert_reg_to_slot main_ticks(base+4) ,:r1 , :r2 , 16
|
2019-08-22 12:26:40 +03:00
|
|
|
end
|
|
|
|
def test_ret_load
|
2019-08-23 10:20:39 +03:00
|
|
|
load_ins = main_ticks(base+5)
|
2019-08-22 12:26:40 +03:00
|
|
|
assert_load load_ins , Parfait::Integer , :r1
|
|
|
|
assert_equal 15 , @interpreter.get_register(load_ins.register).value
|
2018-07-31 18:00:42 +03:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|