BitExpressionsTest.cc 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. /**
  2. * Copyright (c) 2017 committers of YAKINDU and others.
  3. * All rights reserved. This program and the accompanying materials
  4. * are made available under the terms of the Eclipse Public License v1.0
  5. * which accompanies this distribution, and is available at
  6. * http://www.eclipse.org/legal/epl-v10.html
  7. *
  8. * Contributors:
  9. * committers of YAKINDU - initial API and implementation
  10. */
  11. #include <string>
  12. #include "gtest/gtest.h"
  13. #include "BitExpressions.h"
  14. #include "sc_types.h"
  15. BitExpressions* statechart;
  16. class StatemachineTest : public ::testing::Test{
  17. protected:
  18. virtual void SetUp() {
  19. statechart = new BitExpressions();
  20. statechart->init();
  21. }
  22. virtual void TearDown() {
  23. delete statechart;
  24. }
  25. };
  26. TEST_F(StatemachineTest, BitExpressions) {
  27. statechart->enter();
  28. EXPECT_TRUE(statechart->isStateActive(BitExpressions::main_region_StateA));
  29. EXPECT_TRUE(statechart->getDefaultSCI()->get_myBit1()== 5l);
  30. EXPECT_TRUE(statechart->getDefaultSCI()->get_myBit2()== 7l);
  31. statechart->raise_e1();
  32. statechart->runCycle();
  33. EXPECT_TRUE(statechart->isStateActive(BitExpressions::main_region_StateB));
  34. EXPECT_TRUE(statechart->getDefaultSCI()->get_leftBitshift()== 10l);
  35. EXPECT_TRUE(statechart->getDefaultSCI()->get_rightBitshift()== 2l);
  36. EXPECT_TRUE(statechart->getDefaultSCI()->get_complementBitshift()== - 6l );
  37. EXPECT_TRUE(statechart->getDefaultSCI()->get_bitwiseAnd()== 5l);
  38. EXPECT_TRUE(statechart->getDefaultSCI()->get_bitwiseOr()== 7l);
  39. EXPECT_TRUE(statechart->getDefaultSCI()->get_bitwiseXor()== 2l);
  40. }