mirror of
https://github.com/RGBCube/serenity
synced 2025-07-23 09:07:41 +00:00
LibJS: Handle exception in for loop test execution
This commit is contained in:
parent
5eaa7ff406
commit
8ad11df89f
2 changed files with 40 additions and 1 deletions
|
@ -236,9 +236,12 @@ Value ForStatement::execute(Interpreter& interpreter) const
|
||||||
}
|
}
|
||||||
|
|
||||||
if (m_test) {
|
if (m_test) {
|
||||||
while (m_test->execute(interpreter).to_boolean()) {
|
while (true) {
|
||||||
|
auto test_result = m_test->execute(interpreter);
|
||||||
if (interpreter.exception())
|
if (interpreter.exception())
|
||||||
return {};
|
return {};
|
||||||
|
if (!test_result.to_boolean())
|
||||||
|
break;
|
||||||
last_value = interpreter.run(*m_body);
|
last_value = interpreter.run(*m_body);
|
||||||
if (interpreter.exception())
|
if (interpreter.exception())
|
||||||
return {};
|
return {};
|
||||||
|
|
36
Libraries/LibJS/Tests/for-head-errors.js
Normal file
36
Libraries/LibJS/Tests/for-head-errors.js
Normal file
|
@ -0,0 +1,36 @@
|
||||||
|
load("test-common.js");
|
||||||
|
|
||||||
|
try {
|
||||||
|
assertThrowsError(() => {
|
||||||
|
for (var i = foo; i < 100; ++i) {
|
||||||
|
assertNotReached();
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
error: ReferenceError,
|
||||||
|
message: "'foo' not known"
|
||||||
|
});
|
||||||
|
|
||||||
|
assertThrowsError(() => {
|
||||||
|
for (var i = 0; i < foo; ++i) {
|
||||||
|
assertNotReached();
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
error: ReferenceError,
|
||||||
|
message: "'foo' not known"
|
||||||
|
});
|
||||||
|
|
||||||
|
var loopCount = 0;
|
||||||
|
assertThrowsError(() => {
|
||||||
|
for (var i = 0; i < 100; ++foo) {
|
||||||
|
loopCount++;
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
error: ReferenceError,
|
||||||
|
message: "'foo' not known"
|
||||||
|
});
|
||||||
|
assert(loopCount === 1);
|
||||||
|
|
||||||
|
console.log("PASS");
|
||||||
|
} catch (e) {
|
||||||
|
console.log("FAIL: " + e);
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue