test_rules_continue.py 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. import unittest
  2. from modelverse_kernel.main import ModelverseKernel
  3. from utils import execute_until_finished, MvSWrapper
  4. class Testcontinue(unittest.TestCase):
  5. def setUp(self):
  6. self.mvs = MvSWrapper()
  7. self.root = self.mvs.execute("RR", [])[0]
  8. self.mvk = ModelverseKernel(self.root)
  9. def test_basic(self):
  10. # Create a continue construct
  11. root = self.root
  12. task_root = self.mvs.execute("CN", [])[0]
  13. task_frame = self.mvs.execute("CN", [])[0]
  14. phase = self.mvs.execute("CNV", ["init"])[0]
  15. inst = self.mvs.execute("CNV", [{"value":"continue"}])[0]
  16. while_inst = self.mvs.execute("CNV", ["while"])[0]
  17. evalstack_top = self.mvs.execute("CN", [])[0]
  18. evalstack_bottom = self.mvs.execute("CN", [])[0]
  19. init_phase = self.mvs.execute("CNV", ["finish"])[0]
  20. self.mvs.execute("CD", [task_frame, "evalstack", evalstack_top])
  21. self.mvs.execute("CD", [evalstack_top, "prev", evalstack_bottom])
  22. self.mvs.execute("CD", [evalstack_bottom, "inst", while_inst])
  23. self.mvs.execute("CD", [evalstack_bottom, "phase", init_phase])
  24. self.mvs.execute("CD", [root, "task_1", task_root])
  25. self.mvs.execute("CD", [task_root, "frame", task_frame])
  26. self.mvs.execute("CD", [task_frame, "phase", phase])
  27. self.mvs.execute("CD", [task_frame, "IP", inst])
  28. self.mvs.execute("CD", [inst, "while", while_inst])
  29. # Do the invocation until it returns None
  30. execute_until_finished(self.mvk, self.mvs)
  31. # Execution of the command inited, so the MvS should be in the correct new state right now
  32. self.assertEquals(self.mvs.execute("RD", [root, "task_1"])[0], task_root)
  33. self.assertEquals(self.mvs.execute("RD", [task_root, "frame"])[0], task_frame)
  34. self.assertEquals(self.mvs.execute("RV", [self.mvs.execute("RD", [task_frame, "phase"])[0]])[0], "finish")
  35. self.assertEquals(self.mvs.execute("RD", [task_frame, "IP"])[0], inst)
  36. self.assertEquals(self.mvs.execute("RD", [inst, "while"])[0], while_inst)
  37. self.assertNotEquals(self.mvs.execute("RD", [task_frame, "evalstack"])[0], evalstack_top)