test_rules_continue.py 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. import unittest
  2. from modelverse_kernel.generated import ModelverseKernel
  3. from test_generated.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", [])
  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", [])
  13. task_frame = self.mvs.execute("CN", [])
  14. phase = self.mvs.execute("CNV", ["init"])
  15. inst = self.mvs.execute("CNV", [{"value":"continue"}])
  16. while_inst = self.mvs.execute("CNV", ["while"])
  17. evalstack_top = self.mvs.execute("CN", [])
  18. evalstack_bottom = self.mvs.execute("CN", [])
  19. init_phase = self.mvs.execute("CNV", ["finish"])
  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, "task_1", while_inst])
  24. self.mvs.execute("CD", [evalstack_bottom, "phase", init_phase])
  25. self.mvs.execute("CD", [root, "task_1", task_root])
  26. self.mvs.execute("CD", [task_root, "frame", task_frame])
  27. self.mvs.execute("CD", [task_frame, "phase", phase])
  28. self.mvs.execute("CD", [task_frame, "IP", inst])
  29. self.mvs.execute("CD", [inst, "while", while_inst])
  30. # Do the invocation until it returns None
  31. execute_until_finished(self.mvk, self.mvs)
  32. # Execution of the command inited, so the MvS should be in the correct new state right now
  33. self.assertEquals(self.mvs.execute("RD", [root, "task_1"]), task_root)
  34. self.assertEquals(self.mvs.execute("RD", [task_root, "frame"]), task_frame)
  35. self.assertEquals(self.mvs.execute("RV", [self.mvs.execute("RD", [task_frame, "phase"])]), "finish")
  36. self.assertEquals(self.mvs.execute("RD", [task_frame, "IP"]), inst)
  37. self.assertEquals(self.mvs.execute("RD", [inst, "while"]), while_inst)
  38. self.assertNotEquals(self.mvs.execute("RD", [task_frame, "evalstack"]), evalstack_top)