summaryrefslogtreecommitdiffstats
path: root/tests/auto/corelib/statemachine/qstatemachine
diff options
context:
space:
mode:
authorMitch Curtis <mitch.curtis@nokia.com>2012-06-01 14:31:12 +0200
committerQt by Nokia <qt-info@nokia.com>2012-06-05 16:01:29 +0200
commit24aad8d663834d484438c19a433f19d7c044e828 (patch)
treef282f0ce6cbf3b3d8eec9590759a129df062eac3 /tests/auto/corelib/statemachine/qstatemachine
parent21ebd2e4ebe1fb89d8188d0362ef45ff4abe9292 (diff)
Write test to confirm QStateMachine calls connectNotify().
Task-number: QTBUG-16628 Change-Id: I77535fcb9a6ae306df8ccd670ee1bfc32721d66a Reviewed-by: Kent Hansen <kent.hansen@nokia.com> Reviewed-by: Jędrzej Nowacki <jedrzej.nowacki@nokia.com>
Diffstat (limited to 'tests/auto/corelib/statemachine/qstatemachine')
-rw-r--r--tests/auto/corelib/statemachine/qstatemachine/tst_qstatemachine.cpp35
1 files changed, 35 insertions, 0 deletions
diff --git a/tests/auto/corelib/statemachine/qstatemachine/tst_qstatemachine.cpp b/tests/auto/corelib/statemachine/qstatemachine/tst_qstatemachine.cpp
index 34e9b742b1..c5d33e7437 100644
--- a/tests/auto/corelib/statemachine/qstatemachine/tst_qstatemachine.cpp
+++ b/tests/auto/corelib/statemachine/qstatemachine/tst_qstatemachine.cpp
@@ -176,6 +176,7 @@ private slots:
void stopInEventTest_data();
void stopInEventTest();
+ void testIncrementReceivers();
void initialStateIsEnteredBeforeStartedEmitted();
};
@@ -3908,6 +3909,40 @@ void tst_QStateMachine::stopInEventTest()
QVERIFY(machine.configuration().contains(s1));
}
+class IncrementReceiversTest : public QObject
+{
+ Q_OBJECT
+signals:
+ void mySignal();
+public:
+ virtual void connectNotify(const QMetaMethod &signal)
+ {
+ signalList.append(signal);
+ }
+
+ QList<QMetaMethod> signalList;
+};
+
+void tst_QStateMachine::testIncrementReceivers()
+{
+ QStateMachine machine;
+ QState *s1 = new QState(&machine);
+ machine.setInitialState(s1);
+ QFinalState *s2 = new QFinalState(&machine);
+
+ IncrementReceiversTest testObject;
+ s1->addTransition(&testObject, SIGNAL(mySignal()), s2);
+
+ QSignalSpy finishedSpy(&machine, SIGNAL(finished()));
+ machine.start();
+
+ QMetaObject::invokeMethod(&testObject, "mySignal", Qt::QueuedConnection);
+
+ QTRY_COMPARE(finishedSpy.count(), 1);
+ QCOMPARE(testObject.signalList.size(), 1);
+ QCOMPARE(testObject.signalList.at(0), QMetaMethod::fromSignal(&IncrementReceiversTest::mySignal));
+}
+
void tst_QStateMachine::initialStateIsEnteredBeforeStartedEmitted()
{
QStateMachine machine;