v8/test/inspector/debugger/scope-skip-variables-with-empty-name.js
kozyatinskiy 24beac30ee [inspector] Make InspectorTest.sendCommand* private
Introduce Protocol.Domain.method(args) and Protocol.Domain.onEventName() instead.
Renamed InspectorTest.evaluateInPage -> InspectorTest.addScript.
Improved InspectorTest.logMessage.

BUG=chromium:635948
R=dgozman@chromium.org,alph@chromium.org

Review-Url: https://codereview.chromium.org/2390733002
Cr-Commit-Position: refs/heads/master@{#39942}
2016-10-03 23:33:07 +00:00

43 lines
1.1 KiB
JavaScript

// Copyright 2016 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
InspectorTest.addScript(
`function testFunction()
{
for (var a of [1]) {
++a;
debugger;
}
}`);
Protocol.Debugger.enable();
Protocol.Debugger.oncePaused().then(dumpScopeOnPause);
Protocol.Runtime.evaluate({ "expression": "testFunction()" });
var waitScopeObjects = 0;
function dumpScopeOnPause(message)
{
var scopeChain = message.params.callFrames[0].scopeChain;
var localScopeObjectIds = [];
for (var scope of scopeChain) {
if (scope.type === "local")
localScopeObjectIds.push(scope.object.objectId);
}
waitScopeObjects = localScopeObjectIds.length;
if (!waitScopeObjects) {
InspectorTest.completeTest();
} else {
for (var objectId of localScopeObjectIds)
Protocol.Runtime.getProperties({ "objectId" : objectId }).then(dumpProperties);
}
}
function dumpProperties(message)
{
InspectorTest.logMessage(message);
--waitScopeObjects;
if (!waitScopeObjects)
Protocol.Debugger.resume().then(InspectorTest.completeTest);
}