LibJS: Handle exception in for loop test execution

This commit is contained in:
Linus Groh 2020-04-28 20:16:40 +01:00 committed by Andreas Kling
parent 5eaa7ff406
commit 8ad11df89f
Notes: sideshowbarker 2024-07-19 07:12:39 +09:00
2 changed files with 40 additions and 1 deletions

View file

@ -236,9 +236,12 @@ Value ForStatement::execute(Interpreter& interpreter) const
}
if (m_test) {
while (m_test->execute(interpreter).to_boolean()) {
while (true) {
auto test_result = m_test->execute(interpreter);
if (interpreter.exception())
return {};
if (!test_result.to_boolean())
break;
last_value = interpreter.run(*m_body);
if (interpreter.exception())
return {};

View 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);
}