| OLD | NEW |
| 1 <html> | 1 <html> |
| 2 <head> | 2 <head> |
| 3 <script type="text/javascript" src="../../http/tests/inspector-protocol/inspecto
r-protocol-test.js"></script> | 3 <script type="text/javascript" src="../../http/tests/inspector-protocol/inspecto
r-protocol-test.js"></script> |
| 4 <script> | 4 <script> |
| 5 | 5 |
| 6 if (window.testRunner) { | 6 if (window.testRunner) { |
| 7 testRunner.dumpAsText(); | 7 testRunner.dumpAsText(); |
| 8 testRunner.waitUntilDone(); | 8 testRunner.waitUntilDone(); |
| 9 } | 9 } |
| 10 | 10 |
| 11 function junkGenerator() | 11 function junkGenerator() |
| 12 { | 12 { |
| 13 var junkArray = new Array(1000); | 13 var junkArray = new Array(1000); |
| 14 for (var i = 0; i < junkArray.length; ++i) | 14 for (var i = 0; i < junkArray.length; ++i) |
| 15 junkArray[i] = "42 " + i; | 15 junkArray[i] = "42 " + i; |
| 16 window.junkArray = junkArray; | 16 window.junkArray = junkArray; |
| 17 } | 17 } |
| 18 | 18 |
| 19 function setupIntervalAndRunTest() | 19 function setupIntervalAndRunTest() |
| 20 { | 20 { |
| 21 setInterval(junkGenerator, 0); | 21 setInterval(junkGenerator, 0); |
| 22 runTest(); | 22 runTest(); |
| 23 } | 23 } |
| 24 | 24 |
| 25 function test() | 25 function test() |
| 26 { | 26 { |
| 27 InspectorTest.importScript("../../../../inspector-protocol/heap-profiler/res
ources/heap-snapshot-common.js"); | 27 InspectorTest.importScript("../../../../inspector-protocol/heap-profiler/res
ources/heap-snapshot-common.js"); |
| 28 | 28 |
| 29 var gotLastSeenObjectIdEvent = false; | 29 var lastSeenObjectIdEventCount = 0; |
| 30 var gotHeapStatsUpdateEvent = false; | 30 var heapStatsUpdateEventCount = 0; |
| 31 function trackingStarted() | 31 function trackingStarted() |
| 32 { | 32 { |
| 33 InspectorTest.log("SUCCESS: tracking started"); | 33 InspectorTest.log("SUCCESS: tracking started"); |
| 34 } | 34 } |
| 35 | 35 |
| 36 function trackingStopped() | 36 function trackingStopped() |
| 37 { | 37 { |
| 38 if (gotHeapStatsUpdateEvent) | 38 InspectorTest.log("Number of heapStatsUpdate events >= numbrt of lastSee
nObjectId events: " + (heapStatsUpdateEventCount >= lastSeenObjectIdEventCount))
; |
| 39 InspectorTest.log("SUCCESS: heapStatsUpdate arrived"); | 39 InspectorTest.log("At least 2 lastSeenObjectId arrived: " + (lastSeenObj
ectIdEventCount >= 2)); |
| 40 if (gotLastSeenObjectIdEvent) | |
| 41 InspectorTest.log("SUCCESS: lastSeenObjectId arrived"); | |
| 42 InspectorTest.log("SUCCESS: tracking stopped"); | 40 InspectorTest.log("SUCCESS: tracking stopped"); |
| 43 InspectorTest.completeTest(); | 41 InspectorTest.completeTest(); |
| 44 } | 42 } |
| 45 | 43 |
| 46 var fragments = []; | 44 var fragments = []; |
| 47 InspectorTest.eventHandler["HeapProfiler.lastSeenObjectId"] = function(messa
geObject) | 45 InspectorTest.eventHandler["HeapProfiler.lastSeenObjectId"] = function(messa
geObject) |
| 48 { | 46 { |
| 49 | 47 if (++lastSeenObjectIdEventCount <= 2) { |
| 50 var params = messageObject["params"]; | 48 var params = messageObject["params"]; |
| 51 InspectorTest.assert(params, "no params found in event HeapProfiler.last
SeenObjectId"); | 49 InspectorTest.log("HeapProfiler.lastSeenObjectId has params: " + !!p
arams); |
| 52 InspectorTest.assert(params.lastSeenObjectId, "lastSeenObjectId is missi
ng in event HeapProfiler.lastSeenObjectId"); | 50 InspectorTest.log("HeapProfiler.lastSeenObjectId has params.lastSeen
ObjectId: " + !!params.lastSeenObjectId); |
| 53 InspectorTest.assert(params.timestamp, "timestamp is missing in event He
apProfiler.lastSeenObjectId"); | 51 InspectorTest.log("HeapProfiler.lastSeenObjectId has timestamp: " +
!!params.timestamp); |
| 54 InspectorTest.assert(fragments.length, "a heap stats fragment didn't arr
ive before HeapProfiler.lastSeenObjectId"); | 52 InspectorTest.log("A heap stats fragment did arrive before HeapProfi
ler.lastSeenObjectId: " + !!fragments.length); |
| 55 InspectorTest.sendCommand("HeapProfiler.stopTrackingHeapObjects", {}, tr
ackingStopped); | 53 InspectorTest.log(""); |
| 56 gotLastSeenObjectIdEvent = true; | 54 } |
| 55 if (lastSeenObjectIdEventCount == 2) { |
| 56 // Wait for two updates and then stop tracing. |
| 57 InspectorTest.sendCommand("HeapProfiler.stopTrackingHeapObjects", {
}, trackingStopped); |
| 58 } |
| 57 } | 59 } |
| 58 | 60 |
| 59 InspectorTest.eventHandler["HeapProfiler.heapStatsUpdate"] = function(messag
eObject) | 61 InspectorTest.eventHandler["HeapProfiler.heapStatsUpdate"] = function(messag
eObject) |
| 60 { | 62 { |
| 61 var params = messageObject["params"]; | 63 var params = messageObject["params"]; |
| 62 InspectorTest.assert(params, "no params found in event HeapProfiler.heap
StatsUpdate"); | 64 InspectorTest.log("HeapProfiler.heapStatsUpdate has params: " + !!param
s); |
| 63 var statsUpdate = params.statsUpdate; | 65 var statsUpdate = params.statsUpdate; |
| 64 InspectorTest.assert(statsUpdate, "statsUpdata is missing in event HeapP
rofiler.heapStatsUpdate"); | 66 if (++heapStatsUpdateEventCount < 2) { |
| 65 InspectorTest.assert(statsUpdate.length, "statsUpdate should have non ze
ro length"); | 67 InspectorTest.log("HeapProfiler.heapStatsUpdate has statsUpdate: " +
!!statsUpdate); |
| 66 InspectorTest.assert(!(statsUpdate.length % 3), "statsUpdate length must
be a multiple of three"); | 68 InspectorTest.log("statsUpdate length is not zero: " + !!statsUpdate
.length); |
| 67 InspectorTest.assert(!(statsUpdate.length % 3), "statsUpdate length must
be a multiple of three"); | 69 InspectorTest.log("statsUpdate length is a multiple of three: " + !(
statsUpdate.length % 3)); |
| 68 InspectorTest.assert(!statsUpdate[0], "statsUpdate: first fragmentIndex
in first update has to be zero"); | 70 InspectorTest.log("statsUpdate: first fragmentIndex in first update:
" + statsUpdate[0]); |
| 69 InspectorTest.assert(statsUpdate[1], "statsUpdate: total count of object
s should be not zero"); | 71 InspectorTest.log("statsUpdate: total count of objects is not zero:
" + !!statsUpdate[1]); |
| 70 InspectorTest.assert(statsUpdate[2], "statsUpdate: total size of objects
should be not zero"); | 72 InspectorTest.log("statsUpdate: total size of objects is not zero: "
+ !!statsUpdate[2]); |
| 71 fragments.push(statsUpdate); | 73 InspectorTest.log(""); |
| 72 gotHeapStatsUpdateEvent = true; | 74 } |
| 75 fragments.push(statsUpdate); |
| 73 } | 76 } |
| 74 | 77 |
| 75 InspectorTest.sendCommand("HeapProfiler.startTrackingHeapObjects", {}, track
ingStarted); | 78 InspectorTest.sendCommand("HeapProfiler.startTrackingHeapObjects", {}, track
ingStarted); |
| 76 //@ sourceURL=heap-objects-tracking.html | 79 //@ sourceURL=heap-objects-tracking.html |
| 77 } | 80 } |
| 78 </script> | 81 </script> |
| 79 </head> | 82 </head> |
| 80 <body onload="setupIntervalAndRunTest()"> | 83 <body onload="setupIntervalAndRunTest()"> |
| 81 <p>Test that heap tracking actually reports data fragments.</p> | 84 <p>Test that heap tracking actually reports data fragments.</p> |
| 82 </body> | 85 </body> |
| 83 </html> | 86 </html> |
| OLD | NEW |