replace fake compiler with real

less room for error
This commit is contained in:
Torsten 2020-02-28 12:54:17 +02:00
parent 393f0d9a60
commit 887d7b9bbb
10 changed files with 66 additions and 67 deletions

View File

@ -11,8 +11,7 @@ module Risc
class TestCallableCompiler < MiniTest::Test class TestCallableCompiler < MiniTest::Test
def setup def setup
Parfait.boot!({}) Parfait.boot!({})
label = SlotMachine::Label.new("hi","ho") @compiler = Risc.test_compiler
@compiler = CallableCompiler.new(FakeCallable.new , label)
end end
def test_ok def test_ok
assert @compiler assert @compiler
@ -22,7 +21,7 @@ module Risc
end end
def test_current_label def test_current_label
assert_equal Label , @compiler.current.class assert_equal Label , @compiler.current.class
assert_equal "ho" , @compiler.current.name assert_equal "start_label" , @compiler.current.name
end end
def test_slot def test_slot
assert @compiler.risc_instructions assert @compiler.risc_instructions

View File

@ -7,7 +7,7 @@ module Risc
Parfait.boot!(Parfait.default_test_options) Parfait.boot!(Parfait.default_test_options)
@r0 = RegisterValue.new(:r0 , :Message) @r0 = RegisterValue.new(:r0 , :Message)
@r1 = RegisterValue.new(:r1 , :Space) @r1 = RegisterValue.new(:r1 , :Space)
@compiler = FakeCompiler.new @compiler = Risc.test_compiler
end end
def test_resolves_index_ok def test_resolves_index_ok

View File

@ -14,11 +14,11 @@ module SlotMachine
end end
def pest_fail_on_right def pest_fail_on_right
load = SlotLoad.new( "test",[:message, :caller] , [:message ,:receiver,:type] ) load = SlotLoad.new( "test",[:message, :caller] , [:message ,:receiver,:type] )
assert_raises {load.to_risc(Risc::FakeCompiler.new)} assert_raises {load.to_risc(Risc.test_compiler)}
end end
def pest_fail_on_left_long def pest_fail_on_left_long
load = SlotLoad.new("test", [:message, :caller , :type , :type] , [:message,:type] ) load = SlotLoad.new("test", [:message, :caller , :type , :type] , [:message,:type] )
assert_raises {load.to_risc(Risc::FakeCompiler.new)} assert_raises {load.to_risc(Risc.test_compiler)}
end end
end end
end end

View File

@ -6,34 +6,34 @@ module SlotMachine
def setup def setup
Parfait.boot!(Parfait.default_test_options) Parfait.boot!(Parfait.default_test_options)
load = SlotLoad.new("test", [:message, :caller] , [:message,:type] ) load = SlotLoad.new("test", [:message, :caller] , [:message,:type] )
@compiler = Risc::FakeCompiler.new compiler = Risc.test_compiler
load.to_risc(@compiler) load.to_risc(compiler)
@instructions = @compiler.instructions @instructions = compiler.risc_instructions.next
end end
def test_ins_class def test_ins_class
assert_equal Risc::SlotToReg , @instructions[0].class assert_equal Risc::SlotToReg , @instructions.class
end end
def test_ins_next_class def test_ins_next_class
assert_equal Risc::RegToSlot , @instructions[1].class assert_equal Risc::RegToSlot , @instructions.next.class
end end
def test_ins_arr def test_ins_arr
assert_equal :r0 , @instructions[0].array.symbol assert_equal :r0 , @instructions.array.symbol
end end
def test_ins_reg def test_ins_reg
assert_equal :r1 , @instructions[0].register.symbol assert_equal :r2 , @instructions.register.symbol
end end
def test_ins_index def test_ins_index
assert_equal 0 , @instructions[0].index assert_equal 0 , @instructions.index
end end
def test_ins_next_reg def test_ins_next_reg
assert_equal :r1 , @instructions[1].register.symbol assert_equal :r2 , @instructions.next.register.symbol
end end
def test_ins_next_arr def test_ins_next_arr
assert_equal :r0 , @instructions[1].array.symbol assert_equal :r0 , @instructions.next.array.symbol
end end
def test_ins_next_index def test_ins_next_index
assert_equal 6 , @instructions[1].index assert_equal 6 , @instructions.next.index
end end
end end
end end

View File

@ -5,50 +5,47 @@ module SlotMachine
def setup def setup
Parfait.boot!(Parfait.default_test_options) Parfait.boot!(Parfait.default_test_options)
@compiler = Risc::FakeCompiler.new compiler = Risc.test_compiler
load = SlotLoad.new( "test",[:message, :caller, :type] , [:message, :caller , :type] ) load = SlotLoad.new( "test",[:message, :caller, :type] , [:message, :caller , :type] )
load.to_risc(@compiler) load.to_risc(compiler)
@instructions = @compiler.instructions @instructions = compiler.risc_instructions.next
end end
def test_ins_next_classes def test_ins_next_classes
assert_equal Risc::SlotToReg , @instructions[0].class assert_equal Risc::SlotToReg , @instructions.class
assert_equal Risc::SlotToReg , @instructions[1].class assert_equal Risc::SlotToReg , @instructions.next.class
assert_equal Risc::SlotToReg , @instructions[2].class assert_equal Risc::SlotToReg , @instructions.next(2).class
end end
def test_ins_next_next_class def test_ins_next_next_class
assert_equal Risc::RegToSlot , @instructions[3].class assert_equal Risc::RegToSlot , @instructions.next(3).class
assert_equal NilClass , @instructions[4].class assert_equal NilClass , @instructions.next(4).class
end end
def test_ins_next_reg def test_ins_next_reg
assert_equal :r1 , @instructions[1].register.symbol assert_equal :r2 , @instructions.next.register.symbol
end end
def test_ins_next_arr def test_ins_next_arr
assert_equal :r1 , @instructions[1].array.symbol assert_equal :r2 , @instructions.next.array.symbol
end end
def test_ins_next_index def test_ins_next_index
assert_equal 0 , @instructions[1].index assert_equal 0 , @instructions.next.index
end end
def test_ins_next_2_reg def test_ins_next_2_reg
assert_equal :r1 , @instructions[2].register.symbol assert_equal :r3 , @instructions.next(2).register.symbol
end end
def test_ins_next_2_arr def test_ins_next_2_arr
assert_equal :r0 , @instructions[2].array.symbol assert_equal :r0 , @instructions.next(2).array.symbol
end end
def test_ins_next_2_index def test_ins_next_2_index
assert_equal 6 , @instructions[2].index assert_equal 6 , @instructions.next(2).index
end end
def test_ins_next_3_reg def test_ins_next_3_reg
assert_equal :r1 , @instructions[3].register.symbol assert_equal :r2 , @instructions.next(3).register.symbol
end end
def test_ins_next_3_arr def test_ins_next_3_arr
assert_equal :r1 , @instructions[3].array.symbol assert_equal :r3 , @instructions.next(3).array.symbol
end end
def test_ins_next_3_index def test_ins_next_3_index
assert_equal 0 , @instructions[3].index assert_equal 0 , @instructions.next(3).index
end end
end end
end end

View File

@ -7,44 +7,44 @@ module SlotMachine
def setup def setup
Parfait.boot!(Parfait.default_test_options) Parfait.boot!(Parfait.default_test_options)
method = make_method method = make_method
@compiler = Risc::FakeCompiler.new compiler = Risc.test_compiler
@cache_entry = Parfait::CacheEntry.new(method.frame_type, method) @cache_entry = Parfait::CacheEntry.new(method.frame_type, method)
load = SlotLoad.new("test", [@cache_entry , :cached_type] , [:message, :type] ) load = SlotLoad.new("test", [@cache_entry , :cached_type] , [:message, :type] )
load.to_risc(@compiler) load.to_risc(compiler)
@instructions = @compiler.instructions @instructions = compiler.risc_instructions.next
end end
def test_ins_next_class def test_ins_next_class
assert_equal Risc::SlotToReg , @instructions[0].class assert_equal Risc::SlotToReg , @instructions.class
assert_equal Risc::LoadConstant, @instructions[1].class assert_equal Risc::LoadConstant, @instructions.next.class
end end
def test_ins_next_class def test_ins_next_class
assert_equal Risc::RegToSlot , @instructions[2].class assert_equal Risc::RegToSlot , @instructions.next(2).class
assert_equal NilClass , @instructions[3].class assert_equal NilClass , @instructions.next(3).class
end end
def test_ins_load def test_ins_load
assert_equal :r1 , @instructions[1].register.symbol assert_equal :r3 , @instructions.next.register.symbol
assert_equal Parfait::CacheEntry , @instructions[1].constant.class assert_equal Parfait::CacheEntry , @instructions.next.constant.class
end end
def test_ins_next_reg def test_ins_next_reg
assert_equal :r1 , @instructions[0].register.symbol assert_equal :r2 , @instructions.register.symbol
end end
def test_ins_next_arr def test_ins_next_arr
assert_equal :r0 , @instructions[0].array.symbol assert_equal :r0 , @instructions.array.symbol
end end
def test_ins_next_index def test_ins_next_index
assert_equal 0 , @instructions[0].index assert_equal 0 , @instructions.index
end end
def test_ins_next_2_reg def test_ins_next_2_reg
assert_equal :r1 , @instructions[2].register.symbol assert_equal :r2 , @instructions.next(2).register.symbol
end end
def test_ins_next_2_arr def test_ins_next_2_arr
assert_equal :r1 , @instructions[2].array.symbol assert_equal :r3 , @instructions.next(2).array.symbol
end end
def test_ins_next_2_index def test_ins_next_2_index
assert_equal 1 , @instructions[2].index assert_equal 1 , @instructions.next(2).index
end end
end end

View File

@ -5,10 +5,10 @@ module SlotMachine
class TestSlotConstant < MiniTest::Test class TestSlotConstant < MiniTest::Test
def setup def setup
Parfait.boot!(Parfait.default_test_options) Parfait.boot!(Parfait.default_test_options)
compiler = Risc::FakeCompiler.new compiler = Risc.test_compiler
@slotted = Slotted.for(StringConstant.new("hi") , nil) @slotted = Slotted.for(StringConstant.new("hi") , nil)
register = @slotted.to_register(compiler , InstructionMock.new) register = @slotted.to_register(compiler , InstructionMock.new)
@instruction = compiler.instructions.first @instruction = compiler.risc_instructions.next
end end
def test_def_class def test_def_class
assert_equal Risc::LoadConstant , @instruction.class assert_equal Risc::LoadConstant , @instruction.class
@ -23,10 +23,10 @@ module SlotMachine
class TestSlotConstantType < MiniTest::Test class TestSlotConstantType < MiniTest::Test
def setup def setup
Parfait.boot!(Parfait.default_test_options) Parfait.boot!(Parfait.default_test_options)
@compiler = Risc::FakeCompiler.new compiler = Risc.test_compiler
@slotted = Slotted.for(StringConstant.new("hi") , [:type]) @slotted = Slotted.for(StringConstant.new("hi") , [:type])
register = @slotted.to_register(@compiler , InstructionMock.new) register = @slotted.to_register(compiler , InstructionMock.new)
@instruction = @compiler.instructions.first @instruction = compiler.risc_instructions.next
end end
def test_def_class def test_def_class
assert_equal Risc::LoadConstant , @instruction.class assert_equal Risc::LoadConstant , @instruction.class
@ -41,10 +41,10 @@ module SlotMachine
assert_equal "StringConstant.type" , @slotted.to_s assert_equal "StringConstant.type" , @slotted.to_s
end end
def test_def_register2 def test_def_register2
assert_equal :r1 , @compiler.instructions[1].register.symbol assert_equal :r1 , @instruction.next.register.symbol
end end
def test_def_next_index def test_def_next_index
assert_equal 0 , @compiler.instructions[1].index assert_equal 0 , @instruction.next.index
end end
end end
end end

View File

@ -4,10 +4,10 @@ module SlotMachine
class TestSlottedMessage2 < MiniTest::Test class TestSlottedMessage2 < MiniTest::Test
def setup def setup
Parfait.boot!(Parfait.default_test_options) Parfait.boot!(Parfait.default_test_options)
compiler = Risc::FakeCompiler.new compiler = Risc.test_compiler
slotted = SlottedMessage.new([:caller]) slotted = SlottedMessage.new([:caller])
@register = slotted.to_register(compiler , "fake source") @register = slotted.to_register(compiler , "fake source")
@instruction = compiler.instructions.first @instruction = compiler.risc_instructions.next
end end
def test_def_class def test_def_class
assert_equal Risc::SlotToReg , @instruction.class assert_equal Risc::SlotToReg , @instruction.class
@ -19,7 +19,7 @@ module SlotMachine
assert_equal :r0 , @instruction.array.symbol assert_equal :r0 , @instruction.array.symbol
end end
def test_def_register # to next free register r1 def test_def_register # to next free register r1
assert_equal :r1 , @register.symbol assert_equal :r2 , @register.symbol
end end
def test_def_index # at caller index 6 def test_def_index # at caller index 6
assert_equal 6 , @instruction.index assert_equal 6 , @instruction.index

View File

@ -5,10 +5,10 @@ module SlotMachine
class TestSlottedObjectType < MiniTest::Test class TestSlottedObjectType < MiniTest::Test
def setup def setup
Parfait.boot!(Parfait.default_test_options) Parfait.boot!(Parfait.default_test_options)
@compiler = Risc::FakeCompiler.new compiler = Risc.test_compiler
@slotted = Slotted.for(Parfait.object_space , [:type]) @slotted = Slotted.for(Parfait.object_space , [:type])
register = @slotted.to_register(@compiler , InstructionMock.new) register = @slotted.to_register(compiler , InstructionMock.new)
@instruction = @compiler.instructions.first @instruction = compiler.risc_instructions.next
end end
def test_def_class def test_def_class
assert_equal Risc::LoadConstant , @instruction.class assert_equal Risc::LoadConstant , @instruction.class
@ -23,10 +23,10 @@ module SlotMachine
assert_equal "Space.type" , @slotted.to_s assert_equal "Space.type" , @slotted.to_s
end end
def test_def_register2 def test_def_register2
assert_equal :r1 , @compiler.instructions[1].register.symbol assert_equal :r1 , @instruction.next.register.symbol
end end
def test_def_next_index def test_def_next_index
assert_equal 0 , @compiler.instructions[1].index assert_equal 0 , @instruction.next.index
end end
end end
end end

View File

@ -7,6 +7,9 @@ module Risc
:fake_name :fake_name
end end
end end
def self.test_compiler(label = SlotMachine::Label.new("start","start_label"))
CallableCompiler.new( FakeCallable.new , label)
end
class FakeCompiler class FakeCompiler
attr_reader :instructions attr_reader :instructions
def initialize def initialize