better tests to find sneaky module bug
This commit is contained in:
parent
5fd04ee0c5
commit
3fb08acf3f
@ -54,8 +54,9 @@ module Parfait
|
|||||||
|
|
||||||
def create_instance_method method_name , arg_names
|
def create_instance_method method_name , arg_names
|
||||||
raise "uups #{method_name}.#{method_name.class}" unless method_name.is_a?(Symbol)
|
raise "uups #{method_name}.#{method_name.class}" unless method_name.is_a?(Symbol)
|
||||||
clazz = get_layout().object_class()
|
clazz = object_layout().object_class()
|
||||||
raise "??? #{method_name}" unless clazz
|
raise "??? #{method_name}" unless clazz
|
||||||
|
puts "Self: #{self.class} clazz: #{clazz.name}"
|
||||||
Method.new( clazz , method_name , arg_names )
|
Method.new( clazz , method_name , arg_names )
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -63,6 +63,7 @@ module Parfait
|
|||||||
raise "uups #{name}.#{name.class}" unless name.is_a?(Symbol)
|
raise "uups #{name}.#{name.class}" unless name.is_a?(Symbol)
|
||||||
c = self.classes[name]
|
c = self.classes[name]
|
||||||
#puts "MISS, no class #{name} #{name.class}" unless c # " #{self.classes}"
|
#puts "MISS, no class #{name} #{name.class}" unless c # " #{self.classes}"
|
||||||
|
#puts "CLAZZ, #{name} #{c.get_layout.get_length}" if c
|
||||||
c
|
c
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -6,6 +6,9 @@ class TestSpace < MiniTest::Test
|
|||||||
@machine = Virtual.machine
|
@machine = Virtual.machine
|
||||||
@machine.boot
|
@machine.boot
|
||||||
end
|
end
|
||||||
|
def classes
|
||||||
|
[:Kernel,:Word,:List,:Message,:Frame,:Layout,:Class,:Dictionary,:Method]
|
||||||
|
end
|
||||||
def test_booted
|
def test_booted
|
||||||
assert_equal true , @machine.booted
|
assert_equal true , @machine.booted
|
||||||
end
|
end
|
||||||
@ -15,11 +18,39 @@ class TestSpace < MiniTest::Test
|
|||||||
def test_global_space
|
def test_global_space
|
||||||
assert_equal Parfait::Space , Parfait::Space.object_space.class
|
assert_equal Parfait::Space , Parfait::Space.object_space.class
|
||||||
end
|
end
|
||||||
def test_classes
|
def test_classes_class
|
||||||
[:Kernel,:Word,:List,:Message,:Frame,:Layout,:Class,:Dictionary,:Method].each do |name|
|
classes.each do |name|
|
||||||
assert_equal :Class , @machine.space.classes[name].get_class.name
|
assert_equal :Class , @machine.space.classes[name].get_class.name
|
||||||
assert_equal Parfait::Class , @machine.space.classes[name].class
|
assert_equal Parfait::Class , @machine.space.classes[name].class
|
||||||
assert_equal Parfait::Layout , @machine.space.classes[name].get_layout.class
|
assert_equal Parfait::Layout , @machine.space.classes[name].get_layout.class
|
||||||
|
assert_equal name , @machine.space.classes[name].get_class.name
|
||||||
|
end
|
||||||
|
end
|
||||||
|
def test_classes_class
|
||||||
|
classes.each do |name|
|
||||||
|
assert_equal :Class , @machine.space.classes[name].get_class.name
|
||||||
|
assert_equal Parfait::Class , @machine.space.classes[name].class
|
||||||
|
end
|
||||||
|
end
|
||||||
|
def test_classes_layout
|
||||||
|
classes.each do |name|
|
||||||
|
assert_equal Parfait::Layout , @machine.space.classes[name].get_layout.class
|
||||||
|
end
|
||||||
|
end
|
||||||
|
def test_classes_name
|
||||||
|
classes.each do |name|
|
||||||
|
assert_equal name , @machine.space.classes[name].name
|
||||||
|
end
|
||||||
|
end
|
||||||
|
def test_method_name
|
||||||
|
classes.each do |name|
|
||||||
|
cl = @machine.space.classes[name]
|
||||||
|
cl.method_names.each do |mname|
|
||||||
|
puts "Mehtod #{mname}"
|
||||||
|
method = cl.get_instance_method(mname)
|
||||||
|
assert_equal mname , method.name
|
||||||
|
assert_equal name , method.for_class.name
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
def test_messages
|
def test_messages
|
||||||
|
Loading…
Reference in New Issue
Block a user