diff options
author | Michael Brasser <michael.brasser@nokia.com> | 2010-05-11 01:07:23 (GMT) |
---|---|---|
committer | Michael Brasser <michael.brasser@nokia.com> | 2010-05-11 01:07:23 (GMT) |
commit | 129940723d9145a4380f7e44c06cbaa88ee4053b (patch) | |
tree | 7d7849879d084c667cc44c81f66464a3356e802c /tests/auto/declarative/qdeclarativestates/tst_qdeclarativestates.cpp | |
parent | 35bc65ecf89ccc14f2e949f2d2881e899f7c4165 (diff) | |
download | Qt-129940723d9145a4380f7e44c06cbaa88ee4053b.zip Qt-129940723d9145a4380f7e44c06cbaa88ee4053b.tar.gz Qt-129940723d9145a4380f7e44c06cbaa88ee4053b.tar.bz2 |
Correct ownership of signal handlers in state changes.
When a state uses override, we may apply the same replacesignalhandler
on top of itself. Make sure we update ownership accordingly.
Task-number: QTBUG-10523
Diffstat (limited to 'tests/auto/declarative/qdeclarativestates/tst_qdeclarativestates.cpp')
-rw-r--r-- | tests/auto/declarative/qdeclarativestates/tst_qdeclarativestates.cpp | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/tests/auto/declarative/qdeclarativestates/tst_qdeclarativestates.cpp b/tests/auto/declarative/qdeclarativestates/tst_qdeclarativestates.cpp index 13992ad..ea074a4 100644 --- a/tests/auto/declarative/qdeclarativestates/tst_qdeclarativestates.cpp +++ b/tests/auto/declarative/qdeclarativestates/tst_qdeclarativestates.cpp @@ -87,6 +87,7 @@ private slots: void basicBinding(); void signalOverride(); void signalOverrideCrash(); + void signalOverrideCrash2(); void parentChange(); void parentChangeErrors(); void anchorChanges(); @@ -449,6 +450,21 @@ void tst_qdeclarativestates::signalOverrideCrash() rect->doSomething(); } +void tst_qdeclarativestates::signalOverrideCrash2() +{ + QDeclarativeEngine engine; + + QDeclarativeComponent rectComponent(&engine, SRCDIR "/data/signalOverrideCrash2.qml"); + QDeclarativeRectangle *rect = qobject_cast<QDeclarativeRectangle*>(rectComponent.create()); + QVERIFY(rect != 0); + + QDeclarativeItemPrivate::get(rect)->setState("state1"); + QDeclarativeItemPrivate::get(rect)->setState("state2"); + QDeclarativeItemPrivate::get(rect)->setState("state1"); + + delete rect; +} + void tst_qdeclarativestates::parentChange() { QDeclarativeEngine engine; |