 Chromium Code Reviews
 Chromium Code Reviews Issue 10096016:
  Remove Debug object from the user roots in heap profiler.  (Closed) 
  Base URL: https://v8.googlecode.com/svn/branches/bleeding_edge
    
  
    Issue 10096016:
  Remove Debug object from the user roots in heap profiler.  (Closed) 
  Base URL: https://v8.googlecode.com/svn/branches/bleeding_edge| Index: test/cctest/test-heap-profiler.cc | 
| diff --git a/test/cctest/test-heap-profiler.cc b/test/cctest/test-heap-profiler.cc | 
| index 1bd0e671d62fca4bdc8e2acb15426ee5df2d1e79..94b072fa8aaa8e85d1878ae83869c3117f6f0dc9 100644 | 
| --- a/test/cctest/test-heap-profiler.cc | 
| +++ b/test/cctest/test-heap-profiler.cc | 
| @@ -7,6 +7,7 @@ | 
| #include "cctest.h" | 
| #include "heap-profiler.h" | 
| #include "snapshot.h" | 
| +#include "debug.h" | 
| #include "utils-inl.h" | 
| #include "../include/v8-profiler.h" | 
| @@ -1563,6 +1564,30 @@ TEST(SfiAndJsFunctionWeakRefs) { | 
| } | 
| +TEST(NoDebugObjectInSnapshot) { | 
| + v8::HandleScope scope; | 
| + LocalContext env; | 
| + | 
| + v8::internal::Isolate::Current()->debug()->Load(); | 
| + CompileRun("foo = {};"); | 
| + const v8::HeapSnapshot* snapshot = | 
| + v8::HeapProfiler::TakeSnapshot(v8_str("snapshot")); | 
| + const v8::HeapGraphNode* root = snapshot->GetRoot(); | 
| + int count_globals = 0; | 
| 
mnaganov (inactive)
2012/04/17 14:16:14
nit: globals_count sounds more appropriate
 
alexeif
2012/04/17 15:30:10
Done.
 | 
| + for (int i = 0; i < root->GetChildrenCount(); ++i) { | 
| + const v8::HeapGraphEdge* edge = root->GetChild(i); | 
| + if (edge->GetType() == v8::HeapGraphEdge::kShortcut) { | 
| 
mnaganov (inactive)
2012/04/17 14:16:14
Perhaps, expose IsWindowReference to public and us
 
alexeif
2012/04/17 15:30:10
I don't think we need to make it public.
 | 
| + ++count_globals; | 
| + const v8::HeapGraphNode* global = edge->GetToNode(); | 
| 
mnaganov (inactive)
2012/04/17 14:16:14
You can use "GetProperty" helper function defined
 
alexeif
2012/04/17 15:30:10
I don't know the name of the user global.
 
mnaganov (inactive)
2012/04/17 15:35:52
Sorry, I have misread your code.
 | 
| + const v8::HeapGraphNode* foo = | 
| + GetProperty(global, v8::HeapGraphEdge::kProperty, "foo"); | 
| + CHECK_NE(NULL, foo); | 
| + } | 
| + } | 
| + CHECK_EQ(1, count_globals); | 
| +} | 
| + | 
| + | 
| TEST(PersistentHandleCount) { | 
| v8::HandleScope scope; | 
| LocalContext env; |