test_rules_input.py 3.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. import unittest
  2. from modelverse_kernel.main import ModelverseKernel
  3. from utils import execute_until_finished, MvSWrapper
  4. class TestInput(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_input(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", ["init"])[0]
  14. inst = self.mvs.execute("CNV", [{"value":"input"}])[0]
  15. old_retval = self.mvs.execute("CN", [])[0]
  16. input_queue_first = self.mvs.execute("CN", [])[0]
  17. input_queue_next = self.mvs.execute("CN", [])[0]
  18. value = self.mvs.execute("CN", [])[0]
  19. self.mvs.execute("CD", [root, "task_1", task_root])
  20. self.mvs.execute("CD", [task_root, "frame", task_frame])
  21. self.mvs.execute("CD", [task_frame, "phase", phase])
  22. self.mvs.execute("CD", [task_frame, "IP", inst])
  23. self.mvs.execute("CD", [task_frame, "returnvalue", old_retval])
  24. self.mvs.execute("CD", [task_root, "input", input_queue_first])
  25. self.mvs.execute("CD", [input_queue_first, "value", value])
  26. self.mvs.execute("CD", [input_queue_first, "next", input_queue_next])
  27. # Do the invocation until it returns None
  28. execute_until_finished(self.mvk, self.mvs)
  29. # Execution of the command finished, so the MvS should be in the correct new state right now
  30. self.assertEquals(self.mvs.execute("RD", [root, "task_1"])[0], task_root)
  31. self.assertEquals(self.mvs.execute("RD", [task_root, "frame"])[0], task_frame)
  32. self.assertEquals(self.mvs.execute("RV", [self.mvs.execute("RD", [task_frame, "phase"])[0]])[0], "finish")
  33. self.assertEquals(self.mvs.execute("RD", [task_frame, "IP"])[0], inst)
  34. self.assertEquals(self.mvs.execute("RD", [task_frame, "returnvalue"])[0], value)
  35. self.assertEquals(self.mvs.execute("RD", [task_root, "input"])[0], input_queue_next)
  36. def test_input_none(self):
  37. root = self.root
  38. task_root = self.mvs.execute("CN", [])[0]
  39. task_frame = self.mvs.execute("CN", [])[0]
  40. phase = self.mvs.execute("CNV", ["init"])[0]
  41. inst = self.mvs.execute("CNV", [{"value":"input"}])[0]
  42. old_retval = self.mvs.execute("CN", [])[0]
  43. input_queue_first = self.mvs.execute("CN", [])[0]
  44. self.mvs.execute("CD", [root, "task_1", task_root])
  45. self.mvs.execute("CD", [task_root, "frame", task_frame])
  46. self.mvs.execute("CD", [task_frame, "phase", phase])
  47. self.mvs.execute("CD", [task_frame, "IP", inst])
  48. self.mvs.execute("CD", [task_frame, "returnvalue", old_retval])
  49. self.mvs.execute("CD", [task_root, "input", input_queue_first])
  50. # Do the invocation until it returns None
  51. execute_until_finished(self.mvk, self.mvs)
  52. # Execution of the command finished, so the MvS should be in the correct new state right now
  53. self.assertEquals(self.mvs.execute("RD", [root, "task_1"])[0], task_root)
  54. self.assertEquals(self.mvs.execute("RD", [task_root, "frame"])[0], task_frame)
  55. self.assertEquals(self.mvs.execute("RV", [self.mvs.execute("RD", [task_frame, "phase"])[0]])[0], "init")
  56. self.assertEquals(self.mvs.execute("RD", [task_frame, "IP"])[0], inst)
  57. self.assertEquals(self.mvs.execute("RD", [task_frame, "returnvalue"])[0], old_retval)
  58. self.assertEquals(self.mvs.execute("RD", [task_root, "input"])[0], input_queue_first)