mirror of
https://github.com/nodejs/node.git
synced 2025-05-15 14:12:28 +00:00

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>
38 lines
922 B
JavaScript
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})
|
|
`
|
|
}),
|
|
]);
|
|
}
|