test_rules_constant.py 1.7 KB

123456789101112131415161718192021222324252627282930313233343536
  1. import unittest
  2. from modelverse_kernel.main import ModelverseKernel
  3. from utils import execute_until_finished, MvSWrapper
  4. class Testconstant(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_constant(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":"constant"}])[0]
  15. node = self.mvs.execute("CN", [])[0]
  16. returnvalue = self.mvs.execute("CN", [])[0]
  17. self.mvs.execute("CD", [root, "task_1", task_root])
  18. self.mvs.execute("CD", [task_root, "frame", task_frame])
  19. self.mvs.execute("CD", [task_frame, "phase", phase])
  20. self.mvs.execute("CD", [task_frame, "IP", inst])
  21. self.mvs.execute("CD", [task_frame, "returnvalue", returnvalue])
  22. self.mvs.execute("CD", [inst, "node", node])
  23. # Do the invocation until it returns None
  24. execute_until_finished(self.mvk, self.mvs)
  25. # Execution of the command finished, so the MvS should be in the correct new state right now
  26. self.assertEquals(self.mvs.execute("RD", [root, "task_1"])[0], task_root)
  27. self.assertEquals(self.mvs.execute("RD", [task_root, "frame"])[0], task_frame)
  28. self.assertEquals(self.mvs.execute("RV", [self.mvs.execute("RD", [task_frame, "phase"])[0]])[0], "finish")
  29. self.assertEquals(self.mvs.execute("RD", [inst, "node"])[0], node)
  30. self.assertEquals(self.mvs.execute("RD", [task_frame, "returnvalue"])[0], node)