test_rules_input.py 3.6 KB

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