rubyx/test/register/interpreter/helper.rb

66 lines
1.5 KiB
Ruby
Raw Normal View History

require_relative "../helper"
require "register/interpreter"
2015-09-27 21:39:10 +02:00
2017-01-03 21:42:40 +01:00
module Register
module Ticker
include AST::Sexp
2017-01-03 21:42:40 +01:00
def setup
Register.machine.boot
do_clean_compile
Typed.compile( @input )
Collector.collect_space
@interpreter = Interpreter.new
2017-01-03 21:42:40 +01:00
@interpreter.start Register.machine.init
end
2017-01-03 21:42:40 +01:00
# must be after boot, but before main compile, to define method
def do_clean_compile
end
2017-01-03 21:42:40 +01:00
def check_chain should
should.each_with_index do |name , index|
got = ticks(1)
assert_equal got.class ,name , "Wrong class for #{index+1}, expect #{name} , got #{got}"
2017-01-03 21:42:40 +01:00
end
end
2017-01-03 21:42:40 +01:00
def check_return val
assert_equal Parfait::Message , @interpreter.get_register(:r0).class
assert_equal val , @interpreter.get_register(:r0).return_value
2015-09-27 21:39:10 +02:00
end
2017-01-03 21:42:40 +01:00
def ticks num
last = nil
num.times do
last = @interpreter.instruction
@interpreter.tick
end
2017-01-03 21:42:40 +01:00
return last
end
2017-01-03 21:42:40 +01:00
def show_ticks
classes = []
tick = 1
begin
while true and (classes.length < 200)
cl = ticks(1).class
tick += 1
classes << cl
break if cl == NilClass
end
rescue => e
puts "Error at tick #{tick}"
puts e
puts e.backtrace
end
str = classes.to_s.gsub("Register::","")
str.split(",").each_slice(5).each do |line|
puts " " + line.join(",") + ","
2017-01-03 21:42:40 +01:00
end
puts "length = #{classes.length}"
2017-01-03 21:42:40 +01:00
exit(1)
end
end
2015-09-27 21:39:10 +02:00
end