2015-08-04 21:01:20 +02:00
|
|
|
require_relative "helper"
|
|
|
|
|
|
|
|
class AddTest < MiniTest::Test
|
2015-09-20 23:09:11 +02:00
|
|
|
include AST::Sexp
|
2015-09-27 21:39:10 +02:00
|
|
|
include Ticker
|
2015-10-05 23:27:13 +02:00
|
|
|
|
2015-08-04 21:01:20 +02:00
|
|
|
def setup
|
2015-10-22 17:16:29 +02:00
|
|
|
machine = Register.machine.boot
|
2015-10-05 23:27:13 +02:00
|
|
|
code = s(:class, :Object,
|
|
|
|
s(:derives, nil),
|
2015-10-09 16:51:14 +02:00
|
|
|
s(:statements,
|
2015-10-05 23:27:13 +02:00
|
|
|
s(:function, :int,
|
|
|
|
s(:name, :main),
|
|
|
|
s(:parameters),
|
2015-10-09 16:51:14 +02:00
|
|
|
s(:statements,
|
2015-10-16 16:13:08 +02:00
|
|
|
s(:return,
|
|
|
|
s(:operator_value, :+,
|
|
|
|
s(:int, 5),
|
|
|
|
s(:int, 7)))))))
|
|
|
|
|
2015-10-23 13:22:55 +02:00
|
|
|
Soml::Compiler.compile( code )
|
2015-10-18 18:27:02 +02:00
|
|
|
machine.collect
|
2015-08-04 21:01:20 +02:00
|
|
|
@interpreter = Interpreter::Interpreter.new
|
2015-10-22 17:16:29 +02:00
|
|
|
@interpreter.start Register.machine.init
|
2015-08-04 21:01:20 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
def test_branch
|
|
|
|
was = @interpreter.block
|
2015-10-19 15:08:00 +02:00
|
|
|
assert_equal Register::Branch , ticks(1).class
|
2015-08-04 21:01:20 +02:00
|
|
|
assert was != @interpreter.block
|
|
|
|
end
|
|
|
|
def test_load
|
|
|
|
assert_equal Register::LoadConstant , ticks(2).class
|
2015-10-22 17:16:29 +02:00
|
|
|
assert_equal Parfait::Space , Register.machine.objects[ @interpreter.get_register(:r2)].class
|
2015-10-18 16:20:19 +02:00
|
|
|
assert_equal :r2, @interpreter.instruction.array.symbol
|
2015-08-04 21:01:20 +02:00
|
|
|
end
|
|
|
|
def test_get
|
|
|
|
assert_equal Register::GetSlot , ticks(3).class
|
2015-10-18 16:20:19 +02:00
|
|
|
assert @interpreter.get_register( :r2 )
|
|
|
|
assert @interpreter.get_register( :r2 ).is_a? Integer
|
2015-08-04 21:01:20 +02:00
|
|
|
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
|
2015-10-18 16:20:19 +02:00
|
|
|
assert_equal Register::FunctionCall , ticks(6).class
|
2015-08-04 21:01:20 +02:00
|
|
|
assert @interpreter.link
|
|
|
|
end
|
2015-10-16 20:42:11 +02:00
|
|
|
def test_adding
|
2015-10-18 16:20:19 +02:00
|
|
|
done_op = ticks(10)
|
2015-10-16 20:42:11 +02:00
|
|
|
assert_equal Register::OperatorInstruction , done_op.class
|
|
|
|
left = @interpreter.get_register(done_op.left)
|
|
|
|
rr = done_op.right
|
2015-08-08 23:53:04 +02:00
|
|
|
right = @interpreter.get_register(rr)
|
|
|
|
assert_equal Fixnum , left.class
|
|
|
|
assert_equal Fixnum , right.class
|
2015-10-16 20:42:11 +02:00
|
|
|
assert_equal 7 , right
|
|
|
|
assert_equal 12 , left
|
|
|
|
done_tr = ticks(1)
|
|
|
|
assert_equal Register::RegisterTransfer , done_tr.class
|
|
|
|
result = @interpreter.get_register(done_op.left)
|
|
|
|
assert_equal result , 12
|
2015-08-04 21:01:20 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
def test_chain
|
2015-10-18 16:20:19 +02:00
|
|
|
#show_ticks # get output of what is
|
2015-10-19 15:08:00 +02:00
|
|
|
["Branch","LoadConstant","GetSlot","SetSlot","RegisterTransfer",
|
2015-10-18 16:20:19 +02:00
|
|
|
"FunctionCall","SaveReturn","LoadConstant","LoadConstant","OperatorInstruction",
|
|
|
|
"RegisterTransfer","GetSlot","FunctionReturn","RegisterTransfer","Syscall",
|
|
|
|
"NilClass"].each_with_index do |name , index|
|
2015-08-04 21:01:20 +02:00
|
|
|
got = ticks(1)
|
|
|
|
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
|