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

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

Issue 2566383002: ObjectGraph: Establish a HeapIterationScope *before* making the heap writable, least the sweeper in… (Closed)
Patch Set: . Created 4 years 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/object_graph.cc ('k') | runtime/vm/service.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) 2014, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2014, 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/object_graph.h" 6 #include "vm/object_graph.h"
7 #include "vm/unit_test.h" 7 #include "vm/unit_test.h"
8 8
9 namespace dart { 9 namespace dart {
10 10
(...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after
60 { 60 {
61 // No more allocation; raw pointers ahead. 61 // No more allocation; raw pointers ahead.
62 NoSafepointScope no_safepoint_scope; 62 NoSafepointScope no_safepoint_scope;
63 RawObject* b_raw = b.raw(); 63 RawObject* b_raw = b.raw();
64 // Clear handles to cut unintended retained paths. 64 // Clear handles to cut unintended retained paths.
65 b = Array::null(); 65 b = Array::null();
66 c = Array::null(); 66 c = Array::null();
67 d = Array::null(); 67 d = Array::null();
68 ObjectGraph graph(thread); 68 ObjectGraph graph(thread);
69 { 69 {
70 // Compare count and size when 'b' is/isn't skipped. 70 HeapIterationScope iteration_scope(true);
71 CounterVisitor with(Object::null(), Object::null()); 71 {
72 graph.IterateObjectsFrom(a, &with); 72 // Compare count and size when 'b' is/isn't skipped.
73 CounterVisitor without(b_raw, a.raw()); 73 CounterVisitor with(Object::null(), Object::null());
74 graph.IterateObjectsFrom(a, &without); 74 graph.IterateObjectsFrom(a, &with);
75 // Only 'b' and 'c' were cut off. 75 CounterVisitor without(b_raw, a.raw());
76 EXPECT_EQ(2, with.count() - without.count()); 76 graph.IterateObjectsFrom(a, &without);
77 EXPECT_EQ(b_size + c_size, with.size() - without.size()); 77 // Only 'b' and 'c' were cut off.
78 } 78 EXPECT_EQ(2, with.count() - without.count());
79 { 79 EXPECT_EQ(b_size + c_size, with.size() - without.size());
80 // Like above, but iterate over the entire isolate. The counts and sizes 80 }
81 // are thus larger, but the difference should still be just 'b' and 'c'. 81 {
82 CounterVisitor with(Object::null(), Object::null()); 82 // Like above, but iterate over the entire isolate. The counts and sizes
83 graph.IterateObjects(&with); 83 // are thus larger, but the difference should still be just 'b' and 'c'.
84 CounterVisitor without(b_raw, a.raw()); 84 CounterVisitor with(Object::null(), Object::null());
85 graph.IterateObjects(&without); 85 graph.IterateObjects(&with);
86 EXPECT_EQ(2, with.count() - without.count()); 86 CounterVisitor without(b_raw, a.raw());
87 EXPECT_EQ(b_size + c_size, with.size() - without.size()); 87 graph.IterateObjects(&without);
88 EXPECT_EQ(2, with.count() - without.count());
89 EXPECT_EQ(b_size + c_size, with.size() - without.size());
90 }
88 } 91 }
89 EXPECT_EQ(a_size + b_size + c_size + d_size, 92 EXPECT_EQ(a_size + b_size + c_size + d_size,
90 graph.SizeRetainedByInstance(a)); 93 graph.SizeRetainedByInstance(a));
91 } 94 }
92 { 95 {
93 // Get hold of c again. 96 // Get hold of c again.
94 b ^= a.At(10); 97 b ^= a.At(10);
95 c ^= b.At(0); 98 c ^= b.At(0);
96 b = Array::null(); 99 b = Array::null();
97 ObjectGraph graph(thread); 100 ObjectGraph graph(thread);
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after
130 Array& expected_a = Array::Handle(); 133 Array& expected_a = Array::Handle();
131 expected_a ^= path.At(4); 134 expected_a ^= path.At(4);
132 EXPECT(expected_c.raw() == c.raw()); 135 EXPECT(expected_c.raw() == c.raw());
133 EXPECT(expected_b.raw() == a.At(10)); 136 EXPECT(expected_b.raw() == a.At(10));
134 EXPECT(expected_a.raw() == a.raw()); 137 EXPECT(expected_a.raw() == a.raw());
135 } 138 }
136 } 139 }
137 } 140 }
138 141
139 } // namespace dart 142 } // namespace dart
OLDNEW
« no previous file with comments | « runtime/vm/object_graph.cc ('k') | runtime/vm/service.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698