1834ab7246
Adapted various tests to restrictions of inspector protocol: * osr-typing-debug-change: Don't set function variable value. * debug-evaluate-locals: Add variable introduced by eval, run typeof inside evaluate(). * regress-419663: Don't set duplicate breakpoints. * regress-crbug-465298: Compare against function name instead of value. * regress-crbug-621361: Make evaluate return string results. * debug-script: Various counts were off due to new way tests are called. Added new inspector script type. Breakpoints now contain the actual break position, and remote object reconstruction has been extended a bit. BUG=v8:5530 Review-Url: https://codereview.chromium.org/2505363002 Cr-Commit-Position: refs/heads/master@{#41129}
40 lines
994 B
JavaScript
40 lines
994 B
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.
|
|
|
|
|
|
var Debug = debug.Debug;
|
|
var steps = 0;
|
|
var exception = null;
|
|
|
|
function listener(event, execState, eventData, data) {
|
|
if (event != Debug.DebugEvent.Break) return;
|
|
try {
|
|
assertEquals([ debug.ScopeType.Local,
|
|
debug.ScopeType.Script,
|
|
debug.ScopeType.Global],
|
|
execState.frame().allScopes().map(s => s.scopeType()));
|
|
var x_value = execState.frame().evaluate("String(x)").value();
|
|
if (steps < 2) {
|
|
assertEquals("undefined", x_value);
|
|
execState.prepareStep(Debug.StepAction.StepIn);
|
|
} else {
|
|
assertEquals("l => l", x_value);
|
|
}
|
|
steps++;
|
|
} catch (e) {
|
|
exception = e;
|
|
}
|
|
}
|
|
|
|
Debug.setListener(listener);
|
|
|
|
(function() {
|
|
debugger;
|
|
var x = l => l;
|
|
})();
|
|
|
|
Debug.setListener(null);
|
|
assertNull(exception);
|
|
assertEquals(3, steps);
|