| OLD | NEW |
| 1 <html> | 1 <html> |
| 2 <head> | 2 <head> |
| 3 <script src="../../http/tests/inspector/inspector-test.js"></script> | 3 <script src="../../http/tests/inspector/inspector-test.js"></script> |
| 4 <script src="profiler-test.js"></script> | 4 <script src="profiler-test.js"></script> |
| 5 <script> | 5 <script> |
| 6 | 6 |
| 7 function test() | 7 function test() |
| 8 { | 8 { |
| 9 var nodes = 1000; | 9 var nodesCount = 1000; |
| 10 function buildTree(count) | 10 function buildTree(startId, count) |
| 11 { | 11 { |
| 12 // Build a call tree of a chain form: foo1 -> foo2 -> foo3 -> ... | 12 // Build a call tree of a chain form: foo1 -> foo2 -> foo3 -> ... |
| 13 // This should give a O(n^2) nodes in bottom-up tree. | 13 // This should give a O(n^2) nodes in bottom-up tree. |
| 14 var node = null; | 14 var nodes = []; |
| 15 for (var i = count; i > 0; --i) { | 15 for (var i = 1; i <= count; ++i) { |
| 16 var child = node; | 16 nodes.push({ |
| 17 node = { | 17 "id": startId + i - 1, |
| 18 "callFrame": | 18 "callFrame": |
| 19 { | 19 { |
| 20 "functionName": "foo" + i, | 20 "functionName": "foo" + i, |
| 21 "scriptId": "0", | 21 "scriptId": "0", |
| 22 "url": "a.js", | 22 "url": "a.js", |
| 23 "lineNumber": i | 23 "lineNumber": i |
| 24 }, | 24 }, |
| 25 "hitCount": 10, | 25 "hitCount": 10, |
| 26 "callUID": 10000 + i, | 26 "children": i < count ? [startId + i] : [] |
| 27 "children": [] | 27 }); |
| 28 }; | |
| 29 if (child) | |
| 30 node.children.push(child); | |
| 31 } | 28 } |
| 32 return node; | 29 return nodes; |
| 33 } | 30 } |
| 34 var profileAndExpectations = { | 31 var profileAndExpectations = { |
| 35 "title": "profile1", | 32 "title": "profile1", |
| 36 "target": function() { | 33 "target": function() { |
| 37 return WebInspector.targetManager.targets()[0]; | 34 return WebInspector.targetManager.targets()[0]; |
| 38 }, | 35 }, |
| 39 "_profile": { | 36 "_profile": { |
| 40 "head": { | 37 "nodes": [ |
| 41 "callFrame": | |
| 42 { | 38 { |
| 43 "functionName": "(root)", | 39 "id": 0, |
| 44 "scriptId": "0", | 40 "callFrame": |
| 45 "url": "a.js", | 41 { |
| 46 "lineNumber": 0, | 42 "functionName": "(root)", |
| 43 "scriptId": "0", |
| 44 "url": "a.js", |
| 45 "lineNumber": 0, |
| 46 }, |
| 47 "hitCount": 1, |
| 48 "children": [1,2] |
| 47 }, | 49 }, |
| 48 "hitCount": 1, | |
| 49 "callUID": 1000, | |
| 50 "children": [ | |
| 51 { | 50 { |
| 51 "id": 1, |
| 52 "callFrame": | 52 "callFrame": |
| 53 { | 53 { |
| 54 "functionName": "(idle)", | 54 "functionName": "(idle)", |
| 55 "scriptId": "0", | 55 "scriptId": "0", |
| 56 "url": "a.js", | 56 "url": "a.js", |
| 57 "lineNumber": 1 | 57 "lineNumber": 1 |
| 58 }, | 58 }, |
| 59 "hitCount": 2, | 59 "hitCount": 2, |
| 60 "callUID": 2, | |
| 61 "children": [] | 60 "children": [] |
| 62 }, | 61 } |
| 63 buildTree(nodes) | 62 ].concat(buildTree(2, nodesCount)), |
| 64 ] | |
| 65 }, | |
| 66 "idleTime": 0.002, | 63 "idleTime": 0.002, |
| 67 "startTime": 0, | 64 "startTime": 0, |
| 68 "endTime": nodes * 0.01 + 0.003 | 65 "endTime": nodesCount * 0.01 + 0.003 |
| 69 } | 66 } |
| 70 }; | 67 }; |
| 71 var view = new WebInspector.CPUProfileView(profileAndExpectations); | 68 var view = new WebInspector.CPUProfileView(profileAndExpectations); |
| 72 view.viewSelectComboBox.setSelectedIndex(1); | 69 view.viewSelectComboBox.setSelectedIndex(1); |
| 73 view._changeView(); | 70 view._changeView(); |
| 74 var tree = view.profileDataGridTree; | 71 var tree = view.profileDataGridTree; |
| 75 if (!tree) | 72 if (!tree) |
| 76 InspectorTest.addResult("no tree"); | 73 InspectorTest.addResult("no tree"); |
| 77 tree.performSearch(new WebInspector.SearchableView.SearchConfig("foo12", tru
e, false), false); | 74 tree.performSearch(new WebInspector.SearchableView.SearchConfig("foo12", tru
e, false), false); |
| 78 for (var item of tree._searchResults) { | 75 for (var item of tree._searchResults) { |
| 79 var node = item.profileNode; | 76 var node = item.profileNode; |
| 80 InspectorTest.addResult(`${node.callUID}: ${node.functionName} ${node.se
lf} ${node.total}`); | 77 InspectorTest.addResult(`${node.callUID}: ${node.functionName} ${node.se
lf} ${node.total}`); |
| 81 } | 78 } |
| 82 InspectorTest.completeProfilerTest(); | 79 InspectorTest.completeProfilerTest(); |
| 83 } | 80 } |
| 84 | 81 |
| 85 </script> | 82 </script> |
| 86 </head> | 83 </head> |
| 87 <body onload="runTest()"> | 84 <body onload="runTest()"> |
| 88 <p> | 85 <p> |
| 89 Tests that search works for large bottom-up view of CPU profile. | 86 Tests that search works for large bottom-up view of CPU profile. |
| 90 </p> | 87 </p> |
| 91 </body> | 88 </body> |
| 92 </html> | 89 </html> |
| OLD | NEW |