From aad2bc876b71c1c3a0a104f00862facad6ff2640 Mon Sep 17 00:00:00 2001 From: Erik Verbruggen Date: Fri, 22 Apr 2016 15:15:14 +0200 Subject: Set the event type of done.state events to internal. Change-Id: If874a2aa4a47ea1ebe2dd539c09ff19243dd5558 Reviewed-by: Jarek Kobus --- tests/auto/statemachine/eventoccurred.scxml | 8 ++++ tests/auto/statemachine/stateDotDoneEvent.scxml | 53 +++++++++++++++++++++++++ tests/auto/statemachine/tst_statemachine.cpp | 17 ++++++++ tests/auto/statemachine/tst_statemachine.qrc | 1 + 4 files changed, 79 insertions(+) create mode 100644 tests/auto/statemachine/stateDotDoneEvent.scxml (limited to 'tests/auto/statemachine') diff --git a/tests/auto/statemachine/eventoccurred.scxml b/tests/auto/statemachine/eventoccurred.scxml index 6c164c2..87aaf41 100644 --- a/tests/auto/statemachine/eventoccurred.scxml +++ b/tests/auto/statemachine/eventoccurred.scxml @@ -42,4 +42,12 @@ + + + + + diff --git a/tests/auto/statemachine/stateDotDoneEvent.scxml b/tests/auto/statemachine/stateDotDoneEvent.scxml new file mode 100644 index 0000000..82e68ee --- /dev/null +++ b/tests/auto/statemachine/stateDotDoneEvent.scxml @@ -0,0 +1,53 @@ + + + + + + + + + + + + + + + + + + + + + + diff --git a/tests/auto/statemachine/tst_statemachine.cpp b/tests/auto/statemachine/tst_statemachine.cpp index 14628d3..fc20118 100644 --- a/tests/auto/statemachine/tst_statemachine.cpp +++ b/tests/auto/statemachine/tst_statemachine.cpp @@ -47,6 +47,8 @@ private Q_SLOTS: void activeStateNames(); void connectToFinal(); void eventOccurred(); + + void doneDotStateEvent(); }; void tst_StateMachine::stateNames_data() @@ -159,6 +161,21 @@ void tst_StateMachine::eventOccurred() QCOMPARE(qvariant_cast(externalEventOccurredSpy.at(0).at(0)).name(), QLatin1String("externalEvent")); } +void tst_StateMachine::doneDotStateEvent() +{ + QScopedPointer stateMachine(QScxmlStateMachine::fromFile(QString(":/tst_statemachine/stateDotDoneEvent.scxml"))); + QVERIFY(!stateMachine.isNull()); + + QSignalSpy finishedSpy(stateMachine.data(), SIGNAL(finished())); + + stateMachine->start(); + finishedSpy.wait(5000); + QCOMPARE(finishedSpy.count(), 1); + QCOMPARE(stateMachine->activeStateNames(true).size(), 1); + qDebug() << stateMachine->activeStateNames(true); + QVERIFY(stateMachine->activeStateNames(true).contains(QLatin1String("success"))); +} + QTEST_MAIN(tst_StateMachine) diff --git a/tests/auto/statemachine/tst_statemachine.qrc b/tests/auto/statemachine/tst_statemachine.qrc index 59c39af..9ded2d0 100644 --- a/tests/auto/statemachine/tst_statemachine.qrc +++ b/tests/auto/statemachine/tst_statemachine.qrc @@ -4,5 +4,6 @@ statenames.scxml statenamesnested.scxml ids1.scxml + stateDotDoneEvent.scxml -- cgit v1.2.3