Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(323)

Side by Side Diff: runtime/vm/cha_test.cc

Issue 2002583002: Background compiler should validate CHA decisions before committing the code. (Closed) Base URL: git@github.com:dart-lang/sdk.git@master
Patch Set: address comments Created 4 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « runtime/vm/cha.cc ('k') | runtime/vm/compiler.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a 2 // for details. All rights reserved. Use of this source code is governed by a
3 // BSD-style license that can be found in the LICENSE file. 3 // BSD-style license that can be found in the LICENSE file.
4 4
5 #include "platform/assert.h" 5 #include "platform/assert.h"
6 #include "vm/cha.h" 6 #include "vm/cha.h"
7 #include "vm/class_finalizer.h" 7 #include "vm/class_finalizer.h"
8 #include "vm/globals.h" 8 #include "vm/globals.h"
9 #include "vm/symbols.h" 9 #include "vm/symbols.h"
10 #include "vm/unit_test.h" 10 #include "vm/unit_test.h"
11 11
12 namespace dart { 12 namespace dart {
13 13
14 static bool ContainsCid(const GrowableArray<Class*>& classes, intptr_t cid) {
15 for (intptr_t i = 0; i < classes.length(); ++i) {
16 if (classes[i]->id() == cid) return true;
17 }
18 return false;
19 }
20
21 14
22 TEST_CASE(ClassHierarchyAnalysis) { 15 TEST_CASE(ClassHierarchyAnalysis) {
23 const char* kScriptChars = 16 const char* kScriptChars =
24 "class A {" 17 "class A {"
25 " foo() { }" 18 " foo() { }"
26 " bar() { }" 19 " bar() { }"
27 "}\n" 20 "}\n"
28 "class B extends A {" 21 "class B extends A {"
29 "}\n" 22 "}\n"
30 "class C extends B {" 23 "class C extends B {"
(...skipping 51 matching lines...) Expand 10 before | Expand all | Expand 10 after
82 75
83 CHA cha(Thread::Current()); 76 CHA cha(Thread::Current());
84 77
85 EXPECT(cha.HasSubclasses(kInstanceCid)); 78 EXPECT(cha.HasSubclasses(kInstanceCid));
86 EXPECT(!cha.HasSubclasses(kSmiCid)); 79 EXPECT(!cha.HasSubclasses(kSmiCid));
87 EXPECT(!cha.HasSubclasses(kNullCid)); 80 EXPECT(!cha.HasSubclasses(kNullCid));
88 81
89 EXPECT(CHA::HasSubclasses(class_a)); 82 EXPECT(CHA::HasSubclasses(class_a));
90 EXPECT(CHA::HasSubclasses(class_b)); 83 EXPECT(CHA::HasSubclasses(class_b));
91 EXPECT(!CHA::HasSubclasses(class_c)); 84 EXPECT(!CHA::HasSubclasses(class_c));
92 cha.AddToLeafClasses(class_c); 85 cha.AddToGuardedClasses(class_c, /*subclass_count=*/0);
93 EXPECT(!CHA::HasSubclasses(class_d)); 86 EXPECT(!CHA::HasSubclasses(class_d));
94 cha.AddToLeafClasses(class_d); 87 cha.AddToGuardedClasses(class_d, /*subclass_count=*/0);
95 88
96 EXPECT(!ContainsCid(cha.leaf_classes(), class_a.id())); 89 EXPECT(!cha.IsGuardedClass(class_a.id()));
97 EXPECT(!ContainsCid(cha.leaf_classes(), class_b.id())); 90 EXPECT(!cha.IsGuardedClass(class_b.id()));
98 EXPECT(ContainsCid(cha.leaf_classes(), class_c.id())); 91 EXPECT(cha.IsGuardedClass(class_c.id()));
99 EXPECT(ContainsCid(cha.leaf_classes(), class_d.id())); 92 EXPECT(cha.IsGuardedClass(class_d.id()));
100 93
101 const Class& closure_class = 94 const Class& closure_class =
102 Class::Handle(Isolate::Current()->object_store()->closure_class()); 95 Class::Handle(Isolate::Current()->object_store()->closure_class());
103 EXPECT(!cha.HasSubclasses(closure_class.id())); 96 EXPECT(!cha.HasSubclasses(closure_class.id()));
104 } 97 }
105 98
106 } // namespace dart 99 } // namespace dart
OLDNEW
« no previous file with comments | « runtime/vm/cha.cc ('k') | runtime/vm/compiler.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698