2015-08-04 22:01:20 +03:00
|
|
|
require_relative "helper"
|
|
|
|
|
|
|
|
class AddTest < MiniTest::Test
|
2015-09-21 00:09:11 +03:00
|
|
|
include AST::Sexp
|
2015-08-04 22:01:20 +03:00
|
|
|
def setup
|
|
|
|
Virtual.machine.boot
|
2015-09-21 00:09:11 +03:00
|
|
|
code = s(:call,
|
|
|
|
s(:name, :plus),
|
|
|
|
s(:arguments , s(:int , 5)),
|
|
|
|
s(:receiver, s(:int, 2)))
|
2015-09-19 18:56:18 +03:00
|
|
|
Bosl::Compiler.compile( code , Virtual.machine.space.get_main )
|
2015-08-04 22:01:20 +03:00
|
|
|
Virtual.machine.run_before "Register::CallImplementation"
|
|
|
|
@interpreter = Interpreter::Interpreter.new
|
|
|
|
@interpreter.start Virtual.machine.init
|
|
|
|
end
|
|
|
|
|
|
|
|
def ticks num
|
|
|
|
last = nil
|
|
|
|
num.times do
|
|
|
|
last = @interpreter.instruction
|
|
|
|
@interpreter.tick
|
|
|
|
end
|
|
|
|
return last
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_branch
|
|
|
|
was = @interpreter.block
|
|
|
|
assert_equal Register::Branch , ticks(1).class
|
|
|
|
assert was != @interpreter.block
|
|
|
|
end
|
|
|
|
def test_load
|
|
|
|
assert_equal Register::LoadConstant , ticks(2).class
|
|
|
|
assert_equal Parfait::Space , Virtual.machine.objects[ @interpreter.get_register(:r1)].class
|
|
|
|
assert_equal :r1, @interpreter.instruction.array.symbol
|
|
|
|
end
|
|
|
|
def test_get
|
|
|
|
assert_equal Register::GetSlot , ticks(3).class
|
|
|
|
assert @interpreter.get_register( :r3 )
|
|
|
|
assert @interpreter.get_register( :r3 ).is_a? Integer
|
|
|
|
end
|
|
|
|
def test_transfer
|
|
|
|
transfer = ticks 5
|
|
|
|
assert_equal Register::RegisterTransfer , transfer.class
|
|
|
|
assert_equal @interpreter.get_register(transfer.to) , @interpreter.get_register(transfer.from)
|
|
|
|
end
|
|
|
|
def test_call
|
|
|
|
assert_equal Register::FunctionCall , ticks(7).class
|
|
|
|
assert @interpreter.link
|
|
|
|
end
|
2015-08-11 17:22:04 +03:00
|
|
|
def ttest_adding
|
2015-08-07 16:46:55 +03:00
|
|
|
done = ticks(23)
|
|
|
|
assert_equal Register::OperatorInstruction , done.class
|
2015-08-09 00:53:04 +03:00
|
|
|
left = @interpreter.get_register(done.left)
|
|
|
|
rr = done.right
|
|
|
|
right = @interpreter.get_register(rr)
|
|
|
|
assert_equal Fixnum , left.class
|
|
|
|
assert_equal Fixnum , right.class
|
|
|
|
assert_equal 5 , right
|
2015-08-04 22:01:20 +03:00
|
|
|
done = ticks(1)
|
2015-08-07 16:46:55 +03:00
|
|
|
assert_equal Register::RegisterTransfer , done.class
|
2015-08-09 00:53:04 +03:00
|
|
|
result = @interpreter.get_register(rr)
|
|
|
|
assert_equal result , left + right
|
2015-08-04 22:01:20 +03:00
|
|
|
end
|
|
|
|
|
|
|
|
def test_chain
|
|
|
|
["Branch" , "LoadConstant" , "GetSlot" , "SetSlot" , "RegisterTransfer" ,
|
2015-08-07 16:46:55 +03:00
|
|
|
"GetSlot" , "FunctionCall" , "SaveReturn" , "LoadConstant" , "SetSlot" ,
|
2015-08-04 22:01:20 +03:00
|
|
|
"GetSlot" , "GetSlot" , "SetSlot" , "LoadConstant" , "SetSlot" ,
|
2015-08-07 16:46:55 +03:00
|
|
|
"LoadConstant" , "SetSlot" , "RegisterTransfer" , "GetSlot" , "FunctionCall" ,
|
|
|
|
"SaveReturn" , "GetSlot", "OperatorInstruction" , "RegisterTransfer" , "GetSlot" , "GetSlot" ,
|
|
|
|
"GetSlot" , "FunctionReturn" ,"RegisterTransfer" , "Syscall", "NilClass"].each_with_index do |name , index|
|
2015-08-04 22:01:20 +03:00
|
|
|
got = ticks(1)
|
|
|
|
puts got
|
|
|
|
assert got.class.name.index(name) , "Wrong class for #{index+1}, expect #{name} , got #{got}"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
# def test_exit
|
|
|
|
# done = ticks(34)
|
|
|
|
# assert_equal NilClass , done.class
|
|
|
|
# end
|
|
|
|
end
|