2015-07-30 19:18:12 +03:00
|
|
|
require_relative "helper"
|
|
|
|
|
2015-08-04 22:01:20 +03:00
|
|
|
class TestPuts < MiniTest::Test
|
2015-09-21 00:09:11 +03:00
|
|
|
include AST::Sexp
|
2015-09-27 22:39:10 +03:00
|
|
|
include Ticker
|
2015-07-30 19:18:12 +03:00
|
|
|
def setup
|
2015-10-22 18:16:29 +03:00
|
|
|
machine = Register.machine.boot
|
2015-10-06 00:27:13 +03:00
|
|
|
code = s(:class, :Object,
|
|
|
|
s(:derives, nil),
|
2015-10-09 17:51:14 +03:00
|
|
|
s(:statements,
|
2015-10-06 00:27:13 +03:00
|
|
|
s(:function, :int,
|
|
|
|
s(:name, :main),
|
|
|
|
s(:parameters),
|
2015-10-09 17:51:14 +03:00
|
|
|
s(:statements,
|
2015-10-06 00:27:13 +03:00
|
|
|
s(:call,
|
|
|
|
s(:name, :putstring),
|
|
|
|
s(:arguments),
|
|
|
|
s(:receiver,
|
|
|
|
s(:string, "Hello again")))))))
|
2015-09-21 00:09:11 +03:00
|
|
|
|
2015-10-23 14:22:55 +03:00
|
|
|
Soml::Compiler.compile( code )
|
2015-10-18 19:27:02 +03:00
|
|
|
machine.collect
|
2015-07-30 19:18:12 +03:00
|
|
|
@interpreter = Interpreter::Interpreter.new
|
2015-10-22 18:16:29 +03:00
|
|
|
@interpreter.start Register.machine.init
|
2015-07-30 19:18:12 +03:00
|
|
|
end
|
|
|
|
|
|
|
|
def test_branch
|
2015-10-23 21:27:36 +03:00
|
|
|
was = @interpreter.instruction
|
2015-10-19 16:08:00 +03:00
|
|
|
assert_equal Register::Branch , ticks(1).class
|
2015-10-23 21:27:36 +03:00
|
|
|
assert was != @interpreter.instruction
|
|
|
|
assert @interpreter.instruction , "should have gone to next instruction"
|
2015-07-30 19:18:12 +03:00
|
|
|
end
|
|
|
|
def test_load
|
2015-10-23 21:27:36 +03:00
|
|
|
assert_equal Register::LoadConstant , ticks(3).class
|
2015-10-22 18:16:29 +03:00
|
|
|
assert_equal Parfait::Space , Register.machine.objects[ @interpreter.get_register(:r2)].class
|
2015-10-18 17:20:19 +03:00
|
|
|
assert_equal :r2, @interpreter.instruction.array.symbol
|
2015-07-30 19:18:12 +03:00
|
|
|
end
|
|
|
|
def test_get
|
2015-10-23 21:27:36 +03:00
|
|
|
assert_equal Register::GetSlot , ticks(4).class
|
2015-10-18 17:20:19 +03:00
|
|
|
assert @interpreter.get_register( :r1 )
|
|
|
|
assert @interpreter.get_register( :r1 ).is_a? Integer
|
2015-07-30 19:18:12 +03:00
|
|
|
end
|
|
|
|
def test_transfer
|
2015-10-23 21:27:36 +03:00
|
|
|
transfer = ticks 6
|
2015-07-30 19:18:12 +03:00
|
|
|
assert_equal Register::RegisterTransfer , transfer.class
|
|
|
|
assert_equal @interpreter.get_register(transfer.to) , @interpreter.get_register(transfer.from)
|
|
|
|
end
|
|
|
|
def test_call
|
2015-10-23 21:27:36 +03:00
|
|
|
assert_equal Register::FunctionCall , ticks(7).class
|
2015-07-30 19:18:12 +03:00
|
|
|
assert @interpreter.link
|
|
|
|
end
|
|
|
|
def test_save
|
2015-10-23 21:27:36 +03:00
|
|
|
done = ticks(9)
|
2015-07-30 19:18:12 +03:00
|
|
|
assert_equal Register::SaveReturn , done.class
|
|
|
|
assert @interpreter.get_register done.register.symbol
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_chain
|
2015-10-18 17:20:19 +03:00
|
|
|
#show_ticks # get output of what is
|
2015-10-23 21:27:36 +03:00
|
|
|
[ "Branch","Label","LoadConstant","GetSlot","SetSlot",
|
|
|
|
"RegisterTransfer","FunctionCall","Label","SaveReturn","GetSlot",
|
|
|
|
"LoadConstant","SetSlot","LoadConstant","SetSlot","RegisterTransfer",
|
|
|
|
"FunctionCall","Label","SaveReturn","GetSlot","RegisterTransfer",
|
|
|
|
"Syscall","RegisterTransfer","RegisterTransfer","SetSlot","Label",
|
|
|
|
"RegisterTransfer","GetSlot","FunctionReturn","GetSlot","Label",
|
2015-10-18 17:20:19 +03:00
|
|
|
"RegisterTransfer","GetSlot","FunctionReturn","RegisterTransfer","Syscall",
|
|
|
|
"NilClass"].each_with_index do |name , index|
|
2015-07-30 19:18:12 +03:00
|
|
|
got = ticks(1)
|
2015-09-27 19:07:56 +03:00
|
|
|
#puts "TICK #{index}"
|
2015-07-30 19:18:12 +03:00
|
|
|
assert got.class.name.index(name) , "Wrong class for #{index+1}, expect #{name} , got #{got}"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_putstring
|
2015-10-23 21:27:36 +03:00
|
|
|
done = ticks(21)
|
2015-07-30 19:18:12 +03:00
|
|
|
assert_equal Register::Syscall , done.class
|
|
|
|
assert_equal "Hello again" , @interpreter.stdout
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_return
|
2015-10-23 21:27:36 +03:00
|
|
|
done = ticks(28)
|
2015-07-30 19:18:12 +03:00
|
|
|
assert_equal Register::FunctionReturn , done.class
|
2015-10-23 21:27:36 +03:00
|
|
|
assert Register::Label , @interpreter.instruction.class
|
2015-07-30 19:18:12 +03:00
|
|
|
assert @interpreter.instruction.is_a?(Register::Instruction) , "not instruction #{@interpreter.instruction}"
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_exit
|
2015-10-23 21:27:36 +03:00
|
|
|
done = ticks(36)
|
2015-07-30 19:18:12 +03:00
|
|
|
assert_equal NilClass , done.class
|
2015-09-27 22:39:10 +03:00
|
|
|
assert_equal "Hello again" , @interpreter.stdout
|
2015-07-30 19:18:12 +03:00
|
|
|
end
|
|
|
|
end
|