fix tests from NotSame removal

This commit is contained in:
Torsten Ruger 2018-03-24 18:33:19 +02:00
parent 8cee2db1d1
commit a407601f5c
4 changed files with 46 additions and 38 deletions

View File

@ -65,7 +65,7 @@ module Risc
postamble.each {all.pop} postamble.each {all.pop}
str = all.to_s.gsub("Risc::","") str = all.to_s.gsub("Risc::","")
ret = "" ret = ""
str.split(",").each_slice(6).each do |line| str.split(",").each_slice(5).each do |line|
ret += " " + line.join(",") + " ,\n" ret += " " + line.join(",") + " ,\n"
end end
ret ret

View File

@ -7,18 +7,21 @@ module Risc
def setup def setup
super super
@input = "return @a.mod4" @input = "return @a.mod4"
@expect = [LoadConstant, SlotToReg, SlotToReg, SlotToReg, NotSame, SlotToReg , @expect = [LoadConstant, SlotToReg, SlotToReg, SlotToReg, OperatorInstruction ,
SlotToReg, RegToSlot, LoadConstant, SlotToReg, SlotToReg, RegToSlot , IsZero, SlotToReg, SlotToReg, LoadConstant, RegToSlot ,
LoadConstant, SlotToReg, SlotToReg, SlotToReg, SlotToReg, RegToSlot , LoadConstant, SlotToReg, SlotToReg, RegToSlot, LoadConstant ,
LoadConstant, SlotToReg, SlotToReg, SlotToReg, SlotToReg, RegToSlot , SlotToReg, SlotToReg, SlotToReg, SlotToReg, RegToSlot ,
LoadConstant, SlotToReg, RegToSlot, SlotToReg, SlotToReg, SlotToReg , LoadConstant, SlotToReg, SlotToReg, SlotToReg, SlotToReg ,
RegToSlot, LoadConstant, SlotToReg, RegToSlot, SlotToReg, LoadConstant , RegToSlot, LoadConstant, SlotToReg, RegToSlot, SlotToReg ,
FunctionCall, Label, SlotToReg, RegToSlot, Label, LoadConstant , SlotToReg, SlotToReg, RegToSlot, LoadConstant, SlotToReg ,
SlotToReg, SlotToReg, RegToSlot, LoadConstant, SlotToReg, SlotToReg , RegToSlot, SlotToReg, LoadConstant, FunctionCall, Label ,
SlotToReg, SlotToReg, RegToSlot, LoadConstant, SlotToReg, SlotToReg , SlotToReg, LoadConstant, RegToSlot, Label, LoadConstant ,
SlotToReg, SlotToReg, RegToSlot, SlotToReg, SlotToReg, SlotToReg , SlotToReg, SlotToReg, RegToSlot, LoadConstant, SlotToReg ,
RegToSlot, LoadConstant, SlotToReg, DynamicJump, SlotToReg, SlotToReg , SlotToReg, SlotToReg, SlotToReg, RegToSlot, LoadConstant ,
RegToSlot, SlotToReg, SlotToReg, RegToSlot, SlotToReg, SlotToReg , SlotToReg, SlotToReg, SlotToReg, SlotToReg, RegToSlot ,
SlotToReg, SlotToReg, SlotToReg, RegToSlot, LoadConstant ,
SlotToReg, DynamicJump, SlotToReg, SlotToReg, RegToSlot ,
SlotToReg, SlotToReg, RegToSlot, SlotToReg, SlotToReg ,
RegToSlot, SlotToReg, SlotToReg, FunctionReturn] RegToSlot, SlotToReg, SlotToReg, FunctionReturn]
end end
@ -27,11 +30,11 @@ module Risc
end end
def test_function_return def test_function_return
produced = produce_body produced = produce_body
assert_equal FunctionReturn , produced.next(75).class assert_equal FunctionReturn , produced.next(78).class
end end
def test_cache_check def test_cache_check
produced = produce_body produced = produce_body
assert_equal NotSame , produced.next(4).class assert_equal IsZero , produced.next(5).class
end end
end end
end end

View File

@ -7,17 +7,18 @@ module Risc
def setup def setup
super super
@input = "@a.mod4" @input = "@a.mod4"
@expect = [LoadConstant, SlotToReg, SlotToReg, SlotToReg, NotSame, SlotToReg , @expect = [LoadConstant, SlotToReg, SlotToReg, SlotToReg, OperatorInstruction, IsZero ,
SlotToReg, RegToSlot, LoadConstant, SlotToReg, SlotToReg, RegToSlot , SlotToReg, SlotToReg, LoadConstant, RegToSlot, LoadConstant, SlotToReg ,
SlotToReg, RegToSlot, LoadConstant, SlotToReg, SlotToReg, SlotToReg ,
SlotToReg, RegToSlot, LoadConstant, SlotToReg, SlotToReg, SlotToReg ,
SlotToReg, RegToSlot, LoadConstant, SlotToReg, RegToSlot, SlotToReg ,
SlotToReg, SlotToReg, RegToSlot, LoadConstant, SlotToReg, RegToSlot ,
SlotToReg, LoadConstant, FunctionCall, Label, SlotToReg, LoadConstant ,
RegToSlot, Label, LoadConstant, SlotToReg, SlotToReg, RegToSlot ,
LoadConstant, SlotToReg, SlotToReg, SlotToReg, SlotToReg, RegToSlot , LoadConstant, SlotToReg, SlotToReg, SlotToReg, SlotToReg, RegToSlot ,
LoadConstant, SlotToReg, SlotToReg, SlotToReg, SlotToReg, RegToSlot , LoadConstant, SlotToReg, SlotToReg, SlotToReg, SlotToReg, RegToSlot ,
LoadConstant, SlotToReg, RegToSlot, SlotToReg, SlotToReg, SlotToReg , SlotToReg, SlotToReg, SlotToReg, RegToSlot, LoadConstant, SlotToReg ,
RegToSlot, LoadConstant, SlotToReg, RegToSlot, SlotToReg, LoadConstant , DynamicJump]
FunctionCall, Label, SlotToReg, RegToSlot, Label, LoadConstant ,
SlotToReg, SlotToReg, RegToSlot, LoadConstant, SlotToReg, SlotToReg ,
SlotToReg, SlotToReg, RegToSlot, LoadConstant, SlotToReg, SlotToReg ,
SlotToReg, SlotToReg, RegToSlot, SlotToReg, SlotToReg, SlotToReg ,
RegToSlot, LoadConstant, SlotToReg, DynamicJump]
end end
def test_send_instructions def test_send_instructions
@ -25,22 +26,23 @@ module Risc
end end
def test_function_call def test_function_call
produced = produce_body produced = produce_body
assert_equal DynamicJump , produced.next(63).class assert_equal DynamicJump , produced.next(66).class
end end
def test_load_address def test_load_address
produced = produce_body produced = produce_body
assert_equal LoadConstant , produced.next(61).class assert_equal LoadConstant , produced.next(64).class
assert_equal Parfait::CacheEntry , produced.next(61).constant.class assert_equal Parfait::CacheEntry , produced.next(64).constant.class
end end
def test_cache_check def test_cache_check
produced = produce_body produced = produce_body
assert_equal NotSame , produced.next(4).class assert_equal IsZero , produced.next(5).class
assert_equal produced.next(40) , produced.next(4).label assert_equal Label , produced.next(43).class
assert_equal produced.next(43) , produced.next(5).label
end end
def test_check_resolve def test_check_resolve
produced = produce_body produced = produce_body
assert_equal FunctionCall , produced.next(36).class assert_equal FunctionCall , produced.next(38).class
assert_equal :resolve_method ,produced.next(36).method.name assert_equal :resolve_method ,produced.next(38).method.name
end end
end end
end end

View File

@ -11,17 +11,20 @@ module Risc
def test_chain def test_chain
#show_ticks # get output of what is #show_ticks # get output of what is
check_chain [Branch, Label, LoadConstant, SlotToReg, SlotToReg, check_chain [Branch, Label, LoadConstant, SlotToReg, LoadConstant,
RegToSlot, LoadConstant, RegToSlot, FunctionCall, Label, SlotToReg, SlotToReg, RegToSlot, LoadConstant, SlotToReg,
LoadConstant, SlotToReg, SlotToReg, RegToSlot, LoadConstant, SlotToReg, SlotToReg, SlotToReg, RegToSlot, LoadConstant,
SlotToReg, SlotToReg, SlotToReg, SlotToReg, RegToSlot, SlotToReg, SlotToReg, SlotToReg, SlotToReg, RegToSlot,
SlotToReg, RegToSlot, LoadConstant, RegToSlot, FunctionCall,
Label, LoadConstant, SlotToReg, SlotToReg, RegToSlot,
LoadConstant, SlotToReg, SlotToReg, SlotToReg, SlotToReg, LoadConstant, SlotToReg, SlotToReg, SlotToReg, SlotToReg,
RegToSlot, LoadConstant, SlotToReg, RegToSlot, LoadConstant, RegToSlot, LoadConstant, SlotToReg, SlotToReg, SlotToReg,
SlotToReg, RegToSlot, SlotToReg, LoadConstant, FunctionCall, SlotToReg, RegToSlot, LoadConstant, SlotToReg, RegToSlot,
Label, Label, NilClass] LoadConstant, SlotToReg, RegToSlot, SlotToReg, LoadConstant,
FunctionCall, Label, Label, NilClass]
end end
def pest_get def test_get
assert_equal SlotToReg , ticks(4).class assert_equal SlotToReg , ticks(4).class
assert @interpreter.get_register( :r2 ) assert @interpreter.get_register( :r2 )
assert Integer , @interpreter.get_register( :r2 ).class assert Integer , @interpreter.get_register( :r2 ).class