EventDrivenTriggeredByTimeEventTest.cc 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. /* Generated by YAKINDU Statechart Tools code generator. */
  2. #include <string>
  3. #include "gtest/gtest.h"
  4. #include "EventDrivenTriggeredByTimeEvent.h"
  5. #include "sc_runner_timed.h"
  6. #include "sc_types.h"
  7. static EventDrivenTriggeredByTimeEvent* statechart;
  8. //! The timers are managed by a timer service. */
  9. static TimedSctUnitRunner * runner;
  10. class EventDrivenTriggeredByTimeEventTest : public ::testing::Test{
  11. protected:
  12. virtual void SetUp() {
  13. statechart = new EventDrivenTriggeredByTimeEvent();
  14. statechart->init();
  15. runner = new TimedSctUnitRunner(
  16. statechart,
  17. true,
  18. 200
  19. );
  20. statechart->setTimer(runner);
  21. }
  22. virtual void TearDown() {
  23. delete statechart;
  24. delete runner;
  25. }
  26. };
  27. TEST_F(EventDrivenTriggeredByTimeEventTest, timeEventTriggersRunCycle) {
  28. statechart->enter();
  29. EXPECT_TRUE(statechart->isStateActive(EventDrivenTriggeredByTimeEvent::EventDrivenTriggeredByTimeEvent_r_A));
  30. EXPECT_TRUE(statechart->getDefaultSCI()->get_x()== 0l);
  31. runner->proceed_time(999);
  32. EXPECT_TRUE(statechart->isStateActive(EventDrivenTriggeredByTimeEvent::EventDrivenTriggeredByTimeEvent_r_A));
  33. EXPECT_TRUE(statechart->getDefaultSCI()->get_x()== 0l);
  34. runner->proceed_time(1);
  35. EXPECT_TRUE(statechart->isStateActive(EventDrivenTriggeredByTimeEvent::EventDrivenTriggeredByTimeEvent_r_B));
  36. EXPECT_TRUE(statechart->getDefaultSCI()->get_x()== 0l);
  37. EXPECT_TRUE(statechart->getDefaultSCI()->get_transition_count()== 1l);
  38. runner->proceed_time(1000);
  39. EXPECT_TRUE(statechart->isStateActive(EventDrivenTriggeredByTimeEvent::EventDrivenTriggeredByTimeEvent_r_A));
  40. EXPECT_TRUE(statechart->getDefaultSCI()->get_x()== 0l);
  41. EXPECT_TRUE(statechart->getDefaultSCI()->get_transition_count()== 2l);
  42. runner->proceed_time(999000);
  43. EXPECT_TRUE(statechart->isStateActive(EventDrivenTriggeredByTimeEvent::EventDrivenTriggeredByTimeEvent_r_B));
  44. EXPECT_TRUE(statechart->getDefaultSCI()->get_x()== 0l);
  45. EXPECT_TRUE(statechart->getDefaultSCI()->get_transition_count()== 1001l);
  46. runner->proceed_time(999000);
  47. EXPECT_TRUE(statechart->isStateActive(EventDrivenTriggeredByTimeEvent::EventDrivenTriggeredByTimeEvent_r_A));
  48. EXPECT_TRUE(statechart->getDefaultSCI()->get_x()== 0l);
  49. EXPECT_TRUE(statechart->getDefaultSCI()->get_transition_count()== 2000l);
  50. statechart->exit();
  51. }