BitExpressionsTest.cc 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. /* Generated by YAKINDU Statechart Tools code generator. */
  2. #include "gtest/gtest.h"
  3. #include "BitExpressions.h"
  4. #include "sc_timer_service.h"
  5. //! The timers are managed by a timer service. */
  6. static sc_unit_timer_service_t timer_service;
  7. static BitExpressions statechart;
  8. class BitExpressionsTest : public ::testing::Test{
  9. protected:
  10. virtual void SetUp() {
  11. bitExpressions_init(&statechart);
  12. sc_timer_service_init(
  13. &timer_service,
  14. 0,
  15. (sc_run_cycle_fp) &bitExpressions_runCycle,
  16. false,
  17. 200,
  18. &statechart
  19. );
  20. }
  21. };
  22. TEST_F(BitExpressionsTest, BitExpressions) {
  23. bitExpressions_enter(&statechart);
  24. EXPECT_TRUE(bitExpressions_isStateActive(&statechart, BitExpressions_main_region_StateA));
  25. EXPECT_TRUE(bitExpressionsIface_get_myBit1(&statechart)== 5l);
  26. EXPECT_TRUE(bitExpressionsIface_get_myBit2(&statechart)== 7l);
  27. bitExpressionsIface_raise_e1(&statechart);
  28. sc_timer_service_proceed_cycles(&timer_service, 1);
  29. EXPECT_TRUE(bitExpressions_isStateActive(&statechart, BitExpressions_main_region_StateB));
  30. EXPECT_TRUE(bitExpressionsIface_get_leftBitshift(&statechart)== 10l);
  31. EXPECT_TRUE(bitExpressionsIface_get_rightBitshift(&statechart)== 2l);
  32. EXPECT_TRUE(bitExpressionsIface_get_complementBitshift(&statechart)== - 6l );
  33. EXPECT_TRUE(bitExpressionsIface_get_bitwiseAnd(&statechart)== 5l);
  34. EXPECT_TRUE(bitExpressionsIface_get_bitwiseOr(&statechart)== 7l);
  35. EXPECT_TRUE(bitExpressionsIface_get_bitwiseXor(&statechart)== 2l);
  36. }