v8/test/inspector/debugger/limit-size-of-collected-scripts.js
Ulan Degenbaev d1070e417f [inspector] Make collectGarbage of HeapProfiler precise
Instead of forcing GC right away, the function now post a task and
performance GC from the task with an empty stack to avoid false positive
pointers in conservative stack scanning.

Bug: chromium:1098187
Change-Id: I88864845a1e395056c5d5f6e867ad774b87dbb6a
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2307217
Commit-Queue: Ulan Degenbaev <ulan@chromium.org>
Reviewed-by: Simon Zünd <szuend@chromium.org>
Reviewed-by: Peter Marshall <petermarshall@chromium.org>
Cr-Commit-Position: refs/heads/master@{#69444}
2020-08-18 07:24:14 +00:00

45 lines
1.8 KiB
JavaScript

// Copyright 2019 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.
// Flags: --no-stress-incremental-marking
let {session, contextGroup, Protocol} = InspectorTest.start(
'Checks that inspector does not retain old collected scripts.\n');
(async function main() {
InspectorTest.log('Limit scripts cache size to 1MB');
const maxScriptsCacheSize = 1e6;
Protocol.Debugger.enable({maxScriptsCacheSize});
const scriptIds = [];
Protocol.Debugger.onScriptParsed(message => scriptIds.push(message.params.scriptId));
InspectorTest.log('Generate 15 scripts 100KB each');
await Protocol.Runtime.evaluate({
expression: 'for (let i = 0; i < 15; ++i) eval(`"${new Array(5e4).fill("й").join("")}".length`);'});
await Protocol.HeapProfiler.collectGarbage();
const firstPhaseScripts = scriptIds.length;
InspectorTest.log('Generate 15 more scripts 100KB each');
await Protocol.Runtime.evaluate({
expression: 'for (let i = 0; i < 15; ++i) eval(`"${new Array(5e4).fill("й").join("")}".length`);'});
await Protocol.HeapProfiler.collectGarbage();
InspectorTest.log('Check that earlier scripts are gone');
InspectorTest.logMessage(`Total scripts size < 1KB: ${await sizeOfScripts(scriptIds.slice(0, firstPhaseScripts)) < 1e3}`);
InspectorTest.log('Check that some of the later scripts are still there');
InspectorTest.logMessage(`Total scripts size > 850KB: ${await sizeOfScripts(scriptIds) > 850e3}`);
InspectorTest.completeTest();
async function sizeOfScripts(scriptIds) {
let size = 0;
for (const scriptId of scriptIds) {
const result = await Protocol.Debugger.getScriptSource({scriptId});
size += result.result ? result.result.scriptSource.length * 2 : 0;
}
return size;
}
})();