2018-04-23 12:16:46 +02:00
|
|
|
require_relative "../helper"
|
2018-03-24 11:21:46 +01:00
|
|
|
|
|
|
|
module Risc
|
2018-04-01 13:01:17 +02:00
|
|
|
class InterpreterDiv10 < MiniTest::Test
|
2018-03-24 11:21:46 +01:00
|
|
|
include Ticker
|
|
|
|
|
|
|
|
def setup
|
2018-04-01 13:50:13 +02:00
|
|
|
@string_input = as_main("return 25.div10")
|
2018-03-24 11:21:46 +01:00
|
|
|
super
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_chain
|
2018-04-04 19:05:09 +02:00
|
|
|
#show_main_ticks # get output of what is
|
2018-05-24 20:20:56 +02:00
|
|
|
check_main_chain [LoadConstant, LoadConstant, SlotToReg, RegToSlot, RegToSlot,
|
|
|
|
SlotToReg, SlotToReg, RegToSlot, SlotToReg, SlotToReg,
|
2018-07-22 21:29:32 +02:00
|
|
|
RegToSlot, RegToSlot, SlotToReg, Branch, RegToSlot,
|
|
|
|
LoadConstant, SlotToReg, RegToSlot, LoadConstant, SlotToReg,
|
|
|
|
RegToSlot, SlotToReg, FunctionCall, SlotToReg, SlotToReg,
|
|
|
|
SlotToReg, SlotToReg, SlotToReg, SlotToReg, LoadData,
|
|
|
|
OperatorInstruction, LoadData, OperatorInstruction, OperatorInstruction, LoadData,
|
|
|
|
Transfer, Branch, OperatorInstruction, OperatorInstruction, LoadData,
|
|
|
|
Transfer, OperatorInstruction, OperatorInstruction, LoadData, Transfer,
|
|
|
|
OperatorInstruction, OperatorInstruction, LoadData, OperatorInstruction, LoadData,
|
|
|
|
Branch, Transfer, OperatorInstruction, OperatorInstruction, Transfer,
|
2018-05-25 19:40:39 +02:00
|
|
|
LoadData, OperatorInstruction, LoadData, OperatorInstruction, OperatorInstruction,
|
2018-07-22 21:29:32 +02:00
|
|
|
LoadConstant, SlotToReg, SlotToReg, RegToSlot, Branch,
|
|
|
|
RegToSlot, RegToSlot, SlotToReg, SlotToReg, RegToSlot,
|
2018-08-06 13:07:17 +02:00
|
|
|
LoadConstant, SlotToReg, RegToSlot, RegToSlot, SlotToReg,
|
|
|
|
SlotToReg, SlotToReg, FunctionReturn, SlotToReg, SlotToReg,
|
|
|
|
RegToSlot, SlotToReg, Branch, SlotToReg, RegToSlot,
|
|
|
|
Branch, SlotToReg, SlotToReg, RegToSlot, LoadConstant,
|
|
|
|
SlotToReg, RegToSlot, RegToSlot, SlotToReg, SlotToReg,
|
|
|
|
SlotToReg, Branch, FunctionReturn, Transfer, SlotToReg,
|
|
|
|
SlotToReg, Branch, Syscall, NilClass]
|
2018-06-19 17:55:47 +02:00
|
|
|
assert_equal 2 , get_return
|
2018-03-24 11:21:46 +01:00
|
|
|
end
|
|
|
|
|
2018-04-01 13:50:13 +02:00
|
|
|
def test_load_25
|
2018-07-22 21:29:32 +02:00
|
|
|
load_ins = main_ticks 16
|
2018-03-24 11:21:46 +01:00
|
|
|
assert_equal LoadConstant , load_ins.class
|
2018-04-01 13:50:13 +02:00
|
|
|
assert_equal 25 , @interpreter.get_register(load_ins.register).value
|
2018-03-24 11:21:46 +01:00
|
|
|
end
|
2018-05-30 11:54:40 +02:00
|
|
|
def test_return_class
|
2018-08-06 13:07:17 +02:00
|
|
|
ret = main_ticks(78)
|
2018-03-24 11:21:46 +01:00
|
|
|
assert_equal FunctionReturn , ret.class
|
|
|
|
link = @interpreter.get_register( ret.register )
|
2018-05-30 11:54:40 +02:00
|
|
|
assert_equal Fixnum , link.class
|
2018-03-24 11:21:46 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|