Initial implementation of raiseException and test

This commit is contained in:
Dale Glass 2023-03-05 17:27:37 +01:00 committed by ksuprynowicz
parent 0369949d9b
commit 8f82750f2a
3 changed files with 60 additions and 22 deletions

View file

@ -172,28 +172,8 @@ ScriptValue ScriptEngineV8::checkScriptSyntax(ScriptProgramPointer program) {
return undefinedValue();
}*/
bool ScriptEngineV8::raiseException(const V8ScriptValue& exception) {
if (!IS_THREADSAFE_INVOCATION(thread(), __FUNCTION__)) {
return false;
}
//V8TODO
// _v8Isolate->ThrowException(makeError(exception).get());
/*if (QScriptEngine::currentContext()) {
// we have an active context / JS stack frame so throw the exception per usual
QScriptEngine::currentContext()->throwValue(makeError(exception));
return true;
} else if (_scriptManager) {
// we are within a pure C++ stack frame (ie: being called directly by other C++ code)
// in this case no context information is available so just emit the exception for reporting
V8ScriptValue thrown = makeError(exception);
emit _scriptManager->unhandledException(ScriptValue(new ScriptValueV8Wrapper(this, std::move(thrown))));
}*/
//emit _scriptManager->unhandledException(ScriptValue(new ScriptValueV8Wrapper(this, std::move(thrown))));
return false;
}
// Lambda
/*ScriptValue ScriptEngineV8::newLambdaFunction(std::function<V8ScriptValue(V8ScriptContext*, ScriptEngineV8*)> operation,
const V8ScriptValue& data,
@ -1548,7 +1528,7 @@ std::shared_ptr<ScriptException> ScriptEngineV8::uncaughtException() const {
}
bool ScriptEngineV8::raiseException(const QString& error, const QString &reason) {
return raiseException(ScriptValue(), reason);
return raiseException(newValue(error), reason);
}
bool ScriptEngineV8::raiseException(const ScriptValue& exception, const QString &reason) {
@ -1561,10 +1541,38 @@ bool ScriptEngineV8::raiseException(const ScriptValue& exception, const QString
// emit
//return raiseException(qException);
qCCritical(scriptengine) << "Raise exception for reason" << reason << "NOT IMPLEMENTED!";
// qCCritical(scriptengine) << "Raise exception for reason" << reason << "NOT IMPLEMENTED!";
// return false;
return raiseException(ScriptValueV8Wrapper::fullUnwrap(this, exception));
}
bool ScriptEngineV8::raiseException(const V8ScriptValue& exception) {
if (!IS_THREADSAFE_INVOCATION(thread(), __FUNCTION__)) {
return false;
}
_v8Isolate->ThrowException(exception.constGet());
/*if (QScriptEngine::currentContext()) {
// we have an active context / JS stack frame so throw the exception per usual
QScriptEngine::currentContext()->throwValue(makeError(exception));
return true;
} else if (_scriptManager) {
// we are within a pure C++ stack frame (ie: being called directly by other C++ code)
// in this case no context information is available so just emit the exception for reporting
V8ScriptValue thrown = makeError(exception);
emit _scriptManager->unhandledException(ScriptValue(new ScriptValueV8Wrapper(this, std::move(thrown))));
}*/
//emit _scriptManager->unhandledException(ScriptValue(new ScriptValueV8Wrapper(this, std::move(thrown))));
return false;
}
ScriptValue ScriptEngineV8::create(int type, const void* ptr) {
v8::Locker locker(_v8Isolate);
v8::Isolate::Scope isolateScope(_v8Isolate);

View file

@ -218,6 +218,35 @@ void ScriptEngineTests::testRaiseException() {
QVERIFY(ex && ex->errorMessage.contains("Exception test"));
}
void ScriptEngineTests::testRaiseExceptionAndCatch() {
QString script =
"try {"
" testClass.doRaiseTest();"
"} catch (err) {"
" if (err === \"Exception test!\") {"
" print(\"Caught!\");"
" }"
"}"
"Script.stop(true);"
;
QString printed;
auto sm = makeManager(script, "testRaiseCatch.js");
connect(sm.get(), &ScriptManager::printedMessage, [&printed](const QString& message, const QString& engineName){
printed.append(message);
});
sm->engine()->registerGlobalObject("testClass", new TestClass(sm->engine()));
sm->run();
auto ex = sm->getUncaughtException();
QVERIFY(!ex);
QVERIFY(printed == "Caught!");
}
void ScriptEngineTests::scriptTest() {
return;

View file

@ -62,6 +62,7 @@ private slots:
void testRegisterClass();
void testInvokeNonInvokable();
void testRaiseException();
void testRaiseExceptionAndCatch();
private: