summaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
authorKent Hansen <kent.hansen@nokia.com>2012-06-01 20:27:05 +0200
committerQt by Nokia <qt-info@nokia.com>2012-08-02 09:15:34 +0200
commita2d5e37f0f9f7e2d8d7bf5390271f2c478a2a177 (patch)
treec457848ce37160bc9e52a3c7bdd5a9b01fb52956 /tests
parent25d1f3417af555dbfc3b8bf36c785cc0129ef160 (diff)
Fix crash when accessing QObject properties through activation object
Since objects in the scope chain have to be JSActivationObjects, QScriptContext::setActivationObject() creates a proxy object that should delegate access to the actual object. This case was not handled in the toQObject() conversion function, so for activation property access through evaluation (where the this-object would be the proxy object, not the actual QObject), the this-object conversion to QObject would fail, and the assert "this-object must be a QObject" was triggered. Cherry-picked from qt5/qtscript commit 44062ea8e2499f8d2061c7e5be8fb754f2ba4310 Task-number: QTBUG-21760 Change-Id: I284b70ea5c9af3a15dadd4243283afe0d00bcd5a Reviewed-by: Olivier Goffart <ogoffart@woboq.com>
Diffstat (limited to 'tests')
-rw-r--r--tests/auto/qscriptextqobject/tst_qscriptextqobject.cpp18
1 files changed, 18 insertions, 0 deletions
diff --git a/tests/auto/qscriptextqobject/tst_qscriptextqobject.cpp b/tests/auto/qscriptextqobject/tst_qscriptextqobject.cpp
index 773df8a203..cb27878ca8 100644
--- a/tests/auto/qscriptextqobject/tst_qscriptextqobject.cpp
+++ b/tests/auto/qscriptextqobject/tst_qscriptextqobject.cpp
@@ -584,6 +584,7 @@ private slots:
void nestedArrayAsSlotArgument();
void nestedObjectAsSlotArgument_data();
void nestedObjectAsSlotArgument();
+ void propertyAccessThroughActivationObject();
private:
QScriptEngine *m_engine;
@@ -3625,5 +3626,22 @@ void tst_QScriptExtQObject::nestedObjectAsSlotArgument()
}
}
+// QTBUG-21760
+void tst_QScriptExtQObject::propertyAccessThroughActivationObject()
+{
+ QScriptContext *ctx = m_engine->pushContext();
+ ctx->setActivationObject(m_engine->newQObject(m_myObject));
+
+ QVERIFY(m_engine->evaluate("intProperty").isNumber());
+ QVERIFY(m_engine->evaluate("mySlot()").isUndefined());
+ QVERIFY(m_engine->evaluate("mySlotWithStringArg('test')").isUndefined());
+
+ QVERIFY(m_engine->evaluate("dynamicProperty").isError());
+ m_myObject->setProperty("dynamicProperty", 123);
+ QCOMPARE(m_engine->evaluate("dynamicProperty").toInt32(), 123);
+
+ m_engine->popContext();
+}
+
QTEST_MAIN(tst_QScriptExtQObject)
#include "tst_qscriptextqobject.moc"