v8/test/inspector/runtime/evaluate-repl-mode-side-effecting.js
Simon Zünd 230e4ed0e1 Mark intrinsics AsyncFunction{Enter,Reject,Resolve} as side-effect free
This fixes the DevTools console preview when using REPL mode.
AsyncFunction* intriniscs are side-effect free and marking them as such
is correct.

Bug: chromium:1043151
Change-Id: Ie0c36507b98b0c12f3d627c34102c04c27358ff2
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2010106
Reviewed-by: Benedikt Meurer <bmeurer@chromium.org>
Commit-Queue: Simon Zünd <szuend@chromium.org>
Cr-Commit-Position: refs/heads/master@{#65876}
2020-01-21 08:45:17 +00:00

29 lines
890 B
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.
let {Protocol} = InspectorTest.start(
'Tests that Runtime.evaluate with REPL mode correctly detects side-effects.');
Protocol.Runtime.enable();
(async function() {
InspectorTest.log('Test "let" declaration is side-effecting');
await evaluateRepl('let x = 21;');
InspectorTest.log('Test side-effect free expressions can be eagerly evaluated');
await evaluateRepl('1 + 2');
await evaluateRepl('"hello " + "REPL"');
await evaluateRepl('(async function foo() { return 42; })();');
InspectorTest.completeTest();
})();
async function evaluateRepl(expression) {
InspectorTest.logMessage(await Protocol.Runtime.evaluate({
expression: expression,
replMode: true,
throwOnSideEffect: true
}));
}