test_rules_helper.py 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. import unittest
  2. from modelverse_kernel.main import ModelverseKernel
  3. from utils import execute_until_finished, MvSWrapper
  4. class TestHelper(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_next(self):
  10. root = self.root
  11. task_root = self.mvs.execute("CN", [])[0]
  12. task_frame = self.mvs.execute("CN", [])[0]
  13. phase = self.mvs.execute("CNV", ["finish"])[0]
  14. inst = self.mvs.execute("CN", [])[0]
  15. next_inst = self.mvs.execute("CNV", ["next"])[0]
  16. self.mvs.execute("CD", [root, "task_1", task_root])
  17. self.mvs.execute("CD", [task_root, "frame", task_frame])
  18. self.mvs.execute("CD", [task_frame, "phase", phase])
  19. self.mvs.execute("CD", [task_frame, "IP", inst])
  20. self.mvs.execute("CD", [inst, "next", next_inst])
  21. # Do the invocation until it returns None
  22. execute_until_finished(self.mvk, self.mvs)
  23. # Execution of the command finished, so the MvS should be in the correct new state right now
  24. self.assertEquals(self.mvs.execute("RD", [root, "task_1"])[0], task_root)
  25. self.assertEquals(self.mvs.execute("RD", [task_root, "frame"])[0], task_frame)
  26. self.assertEquals(self.mvs.execute("RV", [self.mvs.execute("RD", [task_frame, "phase"])[0]])[0], "init")
  27. self.assertEquals(self.mvs.execute("RD", [inst, "next"])[0], next_inst)
  28. self.assertEquals(self.mvs.execute("RD", [task_frame, "IP"])[0], next_inst)
  29. def test_evalstack(self):
  30. root = self.root
  31. task_root = self.mvs.execute("CN", [])[0]
  32. task_frame = self.mvs.execute("CN", [])[0]
  33. phase = self.mvs.execute("CNV", ["finish"])[0]
  34. inst = self.mvs.execute("CN", [])[0]
  35. evalstack = self.mvs.execute("CN", [])[0]
  36. prev_evalstack = self.mvs.execute("CN", [])[0]
  37. evalstack_inst = self.mvs.execute("CN", [])[0]
  38. evalstack_phase = self.mvs.execute("CN", [])[0]
  39. self.mvs.execute("CD", [root, "task_1", task_root])
  40. self.mvs.execute("CD", [task_root, "frame", task_frame])
  41. self.mvs.execute("CD", [task_frame, "phase", phase])
  42. self.mvs.execute("CD", [task_frame, "IP", inst])
  43. self.mvs.execute("CD", [task_frame, "evalstack", evalstack])
  44. self.mvs.execute("CD", [evalstack, "prev", prev_evalstack])
  45. self.mvs.execute("CD", [prev_evalstack, "inst", evalstack_inst])
  46. self.mvs.execute("CD", [prev_evalstack, "phase", evalstack_phase])
  47. # Do the invocation until it returns None
  48. execute_until_finished(self.mvk, self.mvs)
  49. # Execution of the command finished, so the MvS should be in the correct new state right now
  50. self.assertEquals(self.mvs.execute("RD", [root, "task_1"])[0], task_root)
  51. self.assertEquals(self.mvs.execute("RD", [task_root, "frame"])[0], task_frame)
  52. self.assertEquals(self.mvs.execute("RD", [task_frame, "IP"])[0], evalstack_inst)
  53. self.assertEquals(self.mvs.execute("RD", [task_frame, "phase"])[0], evalstack_phase)
  54. self.assertEquals(self.mvs.execute("RD", [task_frame, "evalstack"])[0], prev_evalstack)