Merge pull request #709 from daleglass-overte/script-test-infinite-require

Script test infinite require
This commit is contained in:
Dale Glass 2023-11-07 18:48:42 +01:00 committed by GitHub
commit 95b6e037ba
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
5 changed files with 35 additions and 0 deletions

View file

@ -155,3 +155,31 @@ void ScriptEngineNetworkedTests::testRequire() {
void ScriptEngineNetworkedTests::testRequireInfinite() {
auto sm = makeManager(
"print(\"Starting\");"
"Script.require('./tests/require_inf_a.js');"
"print(\"Done\");"
"Script.stop(true);", "testRequireInf.js");
QString errors;
QVERIFY(!sm->isRunning());
QVERIFY(!sm->isStopped());
QVERIFY(!sm->isFinished());
connect(sm.get(), &ScriptManager::errorMessage, [&errors](const QString& message, const QString& engineName){
errors.append(message);
});
qInfo() << "About to run script";
sm->run();
QVERIFY(!sm->isRunning());
QVERIFY(!sm->isStopped());
QVERIFY(sm->isFinished());
QVERIFY(errors.contains("Maximum call stack size exceeded"));
}

View file

@ -27,6 +27,7 @@ class ScriptEngineNetworkedTests : public QObject {
private slots:
void initTestCase();
void testRequire();
void testRequireInfinite();
private:

View file

@ -0,0 +1,2 @@
module.exports = { value: 1 };
var a = Script.require('./require_inf_b.js');

View file

@ -0,0 +1,2 @@
module.exports = { value: 1 };
var a = Script.require('./require_inf_c.js');

View file

@ -0,0 +1,2 @@
module.exports = { value: 1 };
var a = Script.require('./require_inf_a.js');