Commit 73f4ac62 authored by Peter Marshall's avatar Peter Marshall Committed by Commit Bot

[inspector] Add a test for const declaration and side effects

Add a test that does the same thing the devtools-frontend does when
evaluating console inputs.

1) Declare a const variable with throwOnSideEffect=true. This should
throw.
2) Declare the same const variable with throwOnSideEffect=false.
This should successfully declare the variable.

Previously it could be the case that even though we threw in 1), the
variable would fail to be initialized in 2) with a re-declaration
error.

Bug: chromium:1043151
Change-Id: I1a6126b518f7bb3788c39b9f8e3adb8850aa962a
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2016587
Commit-Queue: Peter Marshall <petermarshall@chromium.org>
Reviewed-by: 's avatarSimon Zünd <szuend@chromium.org>
Cr-Commit-Position: refs/heads/master@{#65991}
parent d7a2973f
......@@ -53,6 +53,15 @@ Test "const" declaration is side-effecting
}
}
}
Test "const" with side-effects works afterwards
{
id : <messageId>
result : {
result : {
type : undefined
}
}
}
Test side-effect free expressions can be eagerly evaluated
{
id : <messageId>
......
......@@ -13,6 +13,9 @@ Protocol.Runtime.enable();
InspectorTest.log('Test "const" declaration is side-effecting');
await evaluateRepl('const y = 42;');
InspectorTest.log('Test "const" with side-effects works afterwards');
await evaluateReplWithSideEffects('const y = 42;');
InspectorTest.log('Test side-effect free expressions can be eagerly evaluated');
await evaluateRepl('1 + 2');
await evaluateRepl('"hello " + "REPL"');
......@@ -29,3 +32,11 @@ async function evaluateRepl(expression) {
throwOnSideEffect: true
}));
}
async function evaluateReplWithSideEffects(expression) {
InspectorTest.logMessage(await Protocol.Runtime.evaluate({
expression: expression,
replMode: true,
throwOnSideEffect: false
}));
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment