Index: runtime/vm/cha_test.cc |
=================================================================== |
--- runtime/vm/cha_test.cc (revision 39070) |
+++ runtime/vm/cha_test.cc (working copy) |
@@ -11,6 +11,14 @@ |
namespace dart { |
+static bool ContainsCid(const GrowableArray<Class*>& classes, intptr_t cid) { |
+ for (intptr_t i = 0; i < classes.length(); ++i) { |
+ if (classes[i]->id() == cid) return true; |
+ } |
+ return false; |
+} |
+ |
+ |
TEST_CASE(ClassHierarchyAnalysis) { |
const char* kScriptChars = |
"class A {" |
@@ -36,22 +44,18 @@ |
const Class& class_a = Class::Handle( |
lib.LookupClass(String::Handle(Symbols::New("A")))); |
EXPECT(!class_a.IsNull()); |
- const intptr_t class_a_id = class_a.id(); |
const Class& class_b = Class::Handle( |
lib.LookupClass(String::Handle(Symbols::New("B")))); |
EXPECT(!class_b.IsNull()); |
- const intptr_t class_b_id = class_b.id(); |
const Class& class_c = Class::Handle( |
lib.LookupClass(String::Handle(Symbols::New("C")))); |
EXPECT(!class_c.IsNull()); |
- const intptr_t class_c_id = class_c.id(); |
const Class& class_d = Class::Handle( |
lib.LookupClass(String::Handle(Symbols::New("D")))); |
EXPECT(!class_d.IsNull()); |
- const intptr_t class_d_id = class_d.id(); |
const String& function_foo_name = String::Handle(String::New("foo")); |
const String& function_bar_name = String::Handle(String::New("bar")); |
@@ -76,59 +80,26 @@ |
Function::Handle(class_d.LookupDynamicFunction(function_bar_name)); |
EXPECT(!class_d_bar.IsNull()); |
- ZoneGrowableArray<intptr_t>* a_subclass_ids = |
- CHA::GetSubclassIdsOf(class_a_id); |
- EXPECT_EQ(3, a_subclass_ids->length()); |
- EXPECT_EQ(class_b_id, (*a_subclass_ids)[0]); |
- EXPECT_EQ(class_c_id, (*a_subclass_ids)[1]); |
- EXPECT_EQ(class_d_id, (*a_subclass_ids)[2]); |
- ZoneGrowableArray<intptr_t>* b_subclass_ids = |
- CHA::GetSubclassIdsOf(class_b_id); |
- EXPECT_EQ(1, b_subclass_ids->length()); |
- EXPECT_EQ(class_c_id, (*b_subclass_ids)[0]); |
- ZoneGrowableArray<intptr_t>* c_subclass_ids = |
- CHA::GetSubclassIdsOf(class_c_id); |
- EXPECT_EQ(0, c_subclass_ids->length()); |
- ZoneGrowableArray<intptr_t>* d_subclass_ids = |
- CHA::GetSubclassIdsOf(class_d_id); |
- EXPECT_EQ(0, d_subclass_ids->length()); |
+ CHA cha(Isolate::Current()); |
- ZoneGrowableArray<Function*>* foos = |
- CHA::GetNamedInstanceFunctionsOf(*a_subclass_ids, function_foo_name); |
- EXPECT_EQ(2, foos->length()); |
- EXPECT_EQ(class_c_foo.raw(), (*foos)[0]->raw()); |
- EXPECT_EQ(class_d_foo.raw(), (*foos)[1]->raw()); |
+ EXPECT(cha.HasSubclasses(kInstanceCid)); |
+ EXPECT(!cha.HasSubclasses(kSmiCid)); |
+ EXPECT(!cha.HasSubclasses(kNullCid)); |
- ZoneGrowableArray<Function*>* class_a_foo_overrides = |
- CHA::GetOverridesOf(class_a_foo); |
- EXPECT_EQ(2, class_a_foo_overrides->length()); |
- EXPECT_EQ(class_c_foo.raw(), (*class_a_foo_overrides)[0]->raw()); |
- EXPECT_EQ(class_d_foo.raw(), (*class_a_foo_overrides)[1]->raw()); |
+ EXPECT(cha.HasSubclasses(class_a)); |
+ EXPECT(cha.HasSubclasses(class_b)); |
+ EXPECT(!cha.HasSubclasses(class_c)); |
+ EXPECT(!cha.HasSubclasses(class_d)); |
- ZoneGrowableArray<Function*>* bars = |
- CHA::GetNamedInstanceFunctionsOf(*a_subclass_ids, function_bar_name); |
- EXPECT_EQ(1, bars->length()); |
- EXPECT_EQ(class_d_bar.raw(), (*bars)[0]->raw()); |
+ EXPECT(!ContainsCid(cha.leaf_classes(), class_a.id())); |
+ EXPECT(!ContainsCid(cha.leaf_classes(), class_b.id())); |
+ EXPECT(ContainsCid(cha.leaf_classes(), class_c.id())); |
+ EXPECT(ContainsCid(cha.leaf_classes(), class_d.id())); |
- ZoneGrowableArray<Function*>* class_a_bar_overrides = |
- CHA::GetOverridesOf(class_a_bar); |
- EXPECT_EQ(1, class_a_bar_overrides->length()); |
- EXPECT_EQ(class_d_bar.raw(), (*class_a_bar_overrides)[0]->raw()); |
- |
- EXPECT(CHA::HasSubclasses(kInstanceCid)); |
- EXPECT(!CHA::HasSubclasses(kSmiCid)); |
- EXPECT(!CHA::HasSubclasses(kNullCid)); |
- EXPECT(!CHA::HasSubclasses(kDynamicCid)); |
- EXPECT(!CHA::HasSubclasses(kVoidCid)); |
- EXPECT(CHA::HasSubclasses(class_a_id)); |
- EXPECT(CHA::HasSubclasses(class_b_id)); |
- EXPECT(!CHA::HasSubclasses(class_c_id)); |
- EXPECT(!CHA::HasSubclasses(class_d_id)); |
- |
class Class& function_impl_class = |
Class::Handle(Type::Handle(Isolate::Current()->object_store()-> |
function_impl_type()).type_class()); |
- EXPECT(CHA::HasSubclasses(function_impl_class.id())); |
+ EXPECT(cha.HasSubclasses(function_impl_class.id())); |
} |
} // namespace dart |