fixing instruction tests

This commit is contained in:
Torsten 2020-03-08 17:31:16 +02:00
parent 22d513d895
commit e6729b8b60
8 changed files with 37 additions and 37 deletions

View File

@ -25,7 +25,7 @@ module SlotMachine
# return_address of the next_message, for the ReturnSequence to pick it up.
def to_risc(compiler)
method = @method
return_label = Risc.label(self,"continue_#{object_id}")
return_label = Risc.label(self,"after_#{@method.name}_#{object_id}")
return_address = compiler.load_object( return_label )
compiler.build(self.to_s) do
message[:next_message][:return_address] << return_address

View File

@ -11,25 +11,25 @@ module SlotMachine
assert_equal 8 , all.length , all_str
end
def test_1_slot
assert_slot_to_reg risc(1) ,:message , 9 , :"message.arg1"
assert_slot_to_reg 1,:message , 9 , :"message.arg1"
end
def test_2_slot
assert_slot_to_reg risc(2) ,:message , 1 , :"message.next_message"
assert_slot_to_reg 2,:message , 1 , :"message.next_message"
end
def test_3_reg
assert_reg_to_slot risc(3) , :"message.arg1" , :"message.next_message" , 2
assert_reg_to_slot 3, :"message.arg1" , :"message.next_message" , 2
end
def test_4_slot
assert_slot_to_reg risc(4) ,:message , 2 , :"message.receiver"
assert_slot_to_reg 4,:message , 2 , :"message.receiver"
end
def test_5
assert_slot_to_reg risc(5) ,:"message.receiver" , 0 , :"message.receiver.type"
assert_slot_to_reg 5,:"message.receiver" , 0 , :"message.receiver.type"
end
def test_6
assert_slot_to_reg risc(6) ,:message , 1 , :"message.next_message"
assert_slot_to_reg 6,:message , 1 , :"message.next_message"
end
def test_7
assert_reg_to_slot risc(7) , :"message.receiver.type" , :"message.next_message" , 9
assert_reg_to_slot 7, :"message.receiver.type" , :"message.next_message" , 9
end
end
end

View File

@ -9,27 +9,27 @@ module SlotMachine
assert_equal 8 , all.length , all_str
end
def test_1_load
assert_load risc(1) , Risc::Label , "id_"
assert_label risc(1).constant , "continue_"
assert_load 1, Risc::Label , "id_"
assert_label risc(1).constant , "continue_" ,1
end
def test_2_slot
assert_slot_to_reg risc(2) ,:message , 1 , "message.next_message"
assert_slot_to_reg 2,:message , 1 , "message.next_message"
end
def test_3_reg
assert_reg_to_slot risc(3) , "id_" , "message.next_message" , 4
assert_reg_to_slot 3, "id_" , "message.next_message" , 4
end
def test_4_slot
assert_slot_to_reg risc(4) ,:message , 9 , "message.arg1"
assert_slot_to_reg 4,:message , 9 , "message.arg1"
end
def test_5_swap
assert_slot_to_reg risc(5) ,:message , 1 , :message
assert_slot_to_reg 5,:message , 1 , :message
end
def test_6_jump
assert_equal Risc::DynamicJump , risc(6).class
assert_equal :"message.arg1" , risc(6).register.symbol
end
def test_7_label
assert_label risc(7) , "continue_"
assert_label 7, "continue_"
end
end
end

View File

@ -9,30 +9,30 @@ module SlotMachine
assert_equal 9 , all.length , all_str
end
def test_1_load
assert_load risc(1) , Parfait::CacheEntry , "id_"
assert_load 1, Parfait::CacheEntry , "id_"
end
def test_2_slot
assert_slot_to_reg risc(2) , "id_" , 2 , "id_.cached_method"
assert_slot_to_reg 2, "id_" , 2 , "id_.cached_method"
end
def test_3_load
assert_load risc(3) , Risc::Label , "id_"
assert_label risc(3).constant , "continue_"
assert_load 3, Risc::Label , "id_"
assert_label risc(3).constant , "continue_" , 3
end
def test_4_slot
assert_slot_to_reg risc(4) , :message , 1 , "message.next_message"
assert_slot_to_reg 4, :message , 1 , "message.next_message"
end
def test_5_reg
assert_reg_to_slot risc(5) , "id_" , "message.next_message" , 4
assert_reg_to_slot 5, "id_" , "message.next_message" , 4
end
def test_6_slot
assert_slot_to_reg risc(6) , :message , 1 , :message
assert_slot_to_reg 6, :message , 1 , :message
end
def test_7_jump
assert_equal Risc::DynamicJump , risc(7).class
assert_register :jump , "id_.cached_method" , risc(7).register
end
def test_8_label
assert_label risc(8) , "continue_"
assert_label 8, "continue_"
end
end
end

View File

@ -9,7 +9,7 @@ module SlotMachine
assert_equal 2 , all.length , all_str
end
def test_1_slot
assert_branch risc(1) , "target"
assert_branch 1, "target"
end
end
end

View File

@ -10,11 +10,11 @@ module SlotMachine
assert_equal Risc::Label , all.first.class
end
def test_1_label
assert_equal Risc::Label , risc(1).class
assert_label 1 , "target"
end
def test_2_slot
label = @instruction.risc_label( @compiler)
assert_equal risc(1) , label
assert_label label , "target" , 1
end
end
end

View File

@ -9,13 +9,13 @@ module SlotMachine
assert_equal 4 , all.length , all_str
end
def test_1_slot
assert_slot_to_reg risc(1) ,:message , 9 , :"message.arg1"
assert_slot_to_reg 1 ,:message , 9 , :"message.arg1"
end
def test_2_slot
assert_slot_to_reg risc(2) ,:message , 1 , :"message.next_message"
assert_slot_to_reg 2 ,:message , 1 , :"message.next_message"
end
def test_3_reg
assert_reg_to_slot risc(3) , :"message.arg1" , :"message.next_message" , 7
assert_reg_to_slot 3 , :"message.arg1" , :"message.next_message" , 7
end
end
class TestMessageSetupCache < SlotMachineInstructionTest
@ -30,16 +30,16 @@ module SlotMachine
assert_equal 5 , all.length , all_str
end
def test_1_load
assert_load risc(1) , Parfait::CacheEntry , "id_"
assert_load 1 , Parfait::CacheEntry , "id_"
end
def test_2_slot
assert_slot_to_reg risc(2) ,"id_" , 2 , "id_.cached_method"
assert_slot_to_reg 2 ,"id_" , 2 , "id_.cached_method"
end
def test_3_slot
assert_slot_to_reg risc(3) ,:message , 1 , :"message.next_message"
assert_slot_to_reg 3 ,:message , 1 , :"message.next_message"
end
def test_4_reg
assert_reg_to_slot risc(4) , "id_.cached_method" , :"message.next_message" , 7
assert_reg_to_slot 4 , "id_.cached_method" , :"message.next_message" , 7
end
end

View File

@ -11,16 +11,16 @@ module SlotMachine
assert_equal 5 , all.length , all_str
end
def test_1_slot
assert_slot_to_reg risc(1) ,:message , 6 , :"message.caller"
assert_slot_to_reg 1,:message , 6 , :"message.caller"
end
def test_2_slot
assert_slot_to_reg risc(2) ,:message , 1 , :"message.next_message"
assert_slot_to_reg 2,:message , 1 , :"message.next_message"
end
def test_3_op
assert_operator risc(3) , :-, :"message.caller" , :"message.next_message"
assert_operator 3, :-, :"message.caller" , :"message.next_message"
end
def test_4_zero
assert_zero risc(4) , "target"
assert_not_zero 4, "target"
end
end
end