node/deps/v8/test/inspector/runtime/console-time-end-stack.js
Michaël Zasso 9d7cd9b864
deps: update V8 to 12.8.374.13
PR-URL: https://github.com/nodejs/node/pull/54077
Reviewed-By: Jiawen Geng <technicalcute@gmail.com>
Reviewed-By: Richard Lau <rlau@redhat.com>
Reviewed-By: Joyee Cheung <joyeec9h3@gmail.com>
Reviewed-By: Marco Ippolito <marcoippolito54@gmail.com>
2024-08-16 16:03:01 +02:00

38 lines
922 B
JavaScript

// Copyright 2024 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.
let {session, contextGroup, Protocol} = InspectorTest.start(
'Checks that console.timeEnd() always attached exactly one stack frame');
Protocol.Runtime.enable();
InspectorTest.runAsyncTestSuite([
function top() {
return checkStack(1);
},
function deep() {
return checkStack(100);
},
]);
async function checkStack(depth) {
await Promise.all([
Protocol.Runtime.onceConsoleAPICalled().then(({params}) => {
InspectorTest.log('Stack depth: ' + params.stackTrace.callFrames.length);
}),
Protocol.Runtime.evaluate({
expression: `
console.time('foo'),
(function recurse(depth) {
if (depth <= 1) {
console.timeEnd('foo');
} else {
recurse(depth - 1);
}
})(${depth})
`
}),
]);
}