test_rules_if.py 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. import unittest
  2. from modelverse_kernel.main import ModelverseKernel
  3. from utils import execute_until_finished, MvSWrapper
  4. class Testif(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_if_evaluate_condition(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":"if"}])[0]
  15. evalstack = self.mvs.execute("CN", [])[0]
  16. cond = 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", [inst, "cond", cond])
  22. self.mvs.execute("CD", [task_frame, "evalstack", evalstack])
  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], "init")
  29. self.assertEquals(self.mvs.execute("RD", [task_frame, "IP"])[0], cond)
  30. new_evalstack = self.mvs.execute("RD", [task_frame, "evalstack"])[0]
  31. self.assertNotEquals(evalstack, new_evalstack)
  32. self.assertEquals(self.mvs.execute("RD", [new_evalstack, "prev"])[0], evalstack)
  33. self.assertEquals(self.mvs.execute("RD", [evalstack, "inst"])[0], inst)
  34. self.assertEquals(self.mvs.execute("RV", [self.mvs.execute("RD", [evalstack, "phase"])[0]])[0], "cond")
  35. def test_if_true(self):
  36. root = self.root
  37. task_root = self.mvs.execute("CN", [])[0]
  38. task_frame = self.mvs.execute("CN", [])[0]
  39. phase = self.mvs.execute("CNV", ["cond"])[0]
  40. inst = self.mvs.execute("CNV", [{"value":"if"}])[0]
  41. evalstack = self.mvs.execute("CN", [])[0]
  42. returnvalue = self.mvs.execute("CNV", [True])[0]
  43. then = 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, "evalstack", evalstack])
  49. self.mvs.execute("CD", [task_frame, "returnvalue", returnvalue])
  50. self.mvs.execute("CD", [inst, "then", then])
  51. # Do the invocation until it returns None
  52. execute_until_finished(self.mvk, self.mvs)
  53. # Execution of the command finished, so the MvS should be in the correct new state right now
  54. self.assertEquals(self.mvs.execute("RD", [root, "task_1"])[0], task_root)
  55. self.assertEquals(self.mvs.execute("RD", [task_root, "frame"])[0], task_frame)
  56. self.assertEquals(self.mvs.execute("RV", [self.mvs.execute("RD", [task_frame, "phase"])[0]])[0], "init")
  57. self.assertEquals(self.mvs.execute("RD", [task_frame, "IP"])[0], then)
  58. new_evalstack = self.mvs.execute("RD", [task_frame, "evalstack"])[0]
  59. self.assertNotEquals(evalstack, new_evalstack)
  60. self.assertEquals(self.mvs.execute("RD", [new_evalstack, "prev"])[0], evalstack)
  61. self.assertEquals(self.mvs.execute("RD", [evalstack, "inst"])[0], inst)
  62. self.assertEquals(self.mvs.execute("RV", [self.mvs.execute("RD", [evalstack, "phase"])[0]])[0], "finish")
  63. def test_if_false_else(self):
  64. root = self.root
  65. task_root = self.mvs.execute("CN", [])[0]
  66. task_frame = self.mvs.execute("CN", [])[0]
  67. phase = self.mvs.execute("CNV", ["cond"])[0]
  68. inst = self.mvs.execute("CNV", [{"value":"if"}])[0]
  69. evalstack = self.mvs.execute("CN", [])[0]
  70. returnvalue = self.mvs.execute("CNV", [False])[0]
  71. else_inst = self.mvs.execute("CN", [])[0]
  72. self.mvs.execute("CD", [root, "task_1", task_root])
  73. self.mvs.execute("CD", [task_root, "frame", task_frame])
  74. self.mvs.execute("CD", [task_frame, "phase", phase])
  75. self.mvs.execute("CD", [task_frame, "IP", inst])
  76. self.mvs.execute("CD", [task_frame, "evalstack", evalstack])
  77. self.mvs.execute("CD", [task_frame, "returnvalue", returnvalue])
  78. self.mvs.execute("CD", [inst, "else", else_inst])
  79. # Do the invocation until it returns None
  80. execute_until_finished(self.mvk, self.mvs)
  81. # Execution of the command finished, so the MvS should be in the correct new state right now
  82. self.assertEquals(self.mvs.execute("RD", [root, "task_1"])[0], task_root)
  83. self.assertEquals(self.mvs.execute("RD", [task_root, "frame"])[0], task_frame)
  84. self.assertEquals(self.mvs.execute("RV", [self.mvs.execute("RD", [task_frame, "phase"])[0]])[0], "init")
  85. self.assertEquals(self.mvs.execute("RD", [task_frame, "IP"])[0], else_inst)
  86. new_evalstack = self.mvs.execute("RD", [task_frame, "evalstack"])[0]
  87. self.assertNotEquals(evalstack, new_evalstack)
  88. self.assertEquals(self.mvs.execute("RD", [new_evalstack, "prev"])[0], evalstack)
  89. self.assertEquals(self.mvs.execute("RD", [evalstack, "inst"])[0], inst)
  90. self.assertEquals(self.mvs.execute("RV", [self.mvs.execute("RD", [evalstack, "phase"])[0]])[0], "finish")
  91. def test_if_false_no_else(self):
  92. root = self.root
  93. task_root = self.mvs.execute("CN", [])[0]
  94. task_frame = self.mvs.execute("CN", [])[0]
  95. phase = self.mvs.execute("CNV", ["cond"])[0]
  96. inst = self.mvs.execute("CNV", [{"value":"if"}])[0]
  97. evalstack = self.mvs.execute("CN", [])[0]
  98. returnvalue = self.mvs.execute("CNV", [False])[0]
  99. self.mvs.execute("CD", [root, "task_1", task_root])
  100. self.mvs.execute("CD", [task_root, "frame", task_frame])
  101. self.mvs.execute("CD", [task_frame, "phase", phase])
  102. self.mvs.execute("CD", [task_frame, "IP", inst])
  103. self.mvs.execute("CD", [task_frame, "evalstack", evalstack])
  104. self.mvs.execute("CD", [task_frame, "returnvalue", returnvalue])
  105. # Do the invocation until it returns None
  106. execute_until_finished(self.mvk, self.mvs)
  107. # Execution of the command finished, so the MvS should be in the correct new state right now
  108. self.assertEquals(self.mvs.execute("RD", [root, "task_1"])[0], task_root)
  109. self.assertEquals(self.mvs.execute("RD", [task_root, "frame"])[0], task_frame)
  110. self.assertEquals(self.mvs.execute("RV", [self.mvs.execute("RD", [task_frame, "phase"])[0]])[0], "finish")
  111. self.assertEquals(self.mvs.execute("RD", [task_frame, "IP"])[0], inst)