diff options
author | Mitch Curtis <mitch.curtis@nokia.com> | 2012-06-01 14:31:12 +0200 |
---|---|---|
committer | Qt by Nokia <qt-info@nokia.com> | 2012-06-05 16:01:29 +0200 |
commit | 24aad8d663834d484438c19a433f19d7c044e828 (patch) | |
tree | f282f0ce6cbf3b3d8eec9590759a129df062eac3 /tests/auto/corelib/statemachine/qstatemachine/tst_qstatemachine.cpp | |
parent | 21ebd2e4ebe1fb89d8188d0362ef45ff4abe9292 (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/tst_qstatemachine.cpp')
-rw-r--r-- | tests/auto/corelib/statemachine/qstatemachine/tst_qstatemachine.cpp | 35 |
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; |