EventDrivenTriggeredByTimeEventTest.cc 2.3 KB

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