test_instruction_assign.py 4.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. import unittest
  2. from modelverse_kernel.main import ModelverseKernel
  3. from utils import execute_until_finished, MvSWrapper, get_inst, get_phase, get_returnvalue, get_returnvalue_ref, get_inst_ref
  4. class TestAssign(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. self.task_root = self.mvs.execute("CN", [])[0]
  10. self.task_frame = self.mvs.execute("CN", [])[0]
  11. self.symbols = self.mvs.execute("CN", [])[0]
  12. self.evalstack = self.mvs.execute("CN", [])[0]
  13. self.returnvalue = self.mvs.execute("CN", [])[0]
  14. self.phase = self.mvs.execute("CNV", ["init"])[0]
  15. self.mvs.execute("CD", [self.root, "task_1", self.task_root])
  16. self.mvs.execute("CD", [self.task_root, "frame", self.task_frame])
  17. self.mvs.execute("CD", [self.task_frame, "symbols", self.symbols])
  18. self.mvs.execute("CD", [self.task_frame, "evalstack", self.evalstack])
  19. self.mvs.execute("CD", [self.task_frame, "phase", self.phase])
  20. self.mvs.execute("CD", [self.task_frame, "returnvalue", self.returnvalue])
  21. def test_assign_simple(self):
  22. """
  23. Test the code:
  24. a = True
  25. """
  26. self.var = self.mvs.execute("CN", [])[0]
  27. self.value = self.mvs.execute("CN", [])[0]
  28. self.previous = self.mvs.execute("CN", [])[0]
  29. self.const = self.mvs.execute("CNV", [{"value":"constant"}])[0]
  30. self.const_value = self.mvs.execute("CNV", [True])[0]
  31. self.inst = self.mvs.execute("CNV", [{"value":"assign"}])[0]
  32. self.resolve = self.mvs.execute("CNV", [{"value":"resolve"}])[0]
  33. self.mvs.execute("CD", [self.task_frame, "IP", self.inst])
  34. self.mvs.execute("CD", [self.inst, "var", self.resolve])
  35. self.mvs.execute("CD", [self.inst, "value", self.const])
  36. self.mvs.execute("CD", [self.resolve, "var", self.var])
  37. self.mvs.execute("CD", [self.value, "value", self.previous])
  38. self.mvs.execute("CD", [self.const, "node", self.const_value])
  39. t = self.mvs.execute("CE", [self.symbols, self.value])[0]
  40. self.mvs.execute("CE", [t, self.var])
  41. ### Execute rules
  42. self.assertEquals(get_inst(self.root, self.mvs), "assign")
  43. self.assertEquals(get_phase(self.root, self.mvs), "init")
  44. execute_until_finished(self.mvk, self.mvs)
  45. self.assertEquals(get_inst(self.root, self.mvs), "resolve")
  46. self.assertEquals(get_phase(self.root, self.mvs), "init")
  47. execute_until_finished(self.mvk, self.mvs)
  48. self.assertEquals(get_inst(self.root, self.mvs), "resolve")
  49. self.assertEquals(get_phase(self.root, self.mvs), "finish")
  50. self.assertEquals(get_returnvalue_ref(self.root, self.mvs), self.value)
  51. execute_until_finished(self.mvk, self.mvs)
  52. self.assertEquals(get_inst(self.root, self.mvs), "assign")
  53. self.assertEquals(get_phase(self.root, self.mvs), "value")
  54. execute_until_finished(self.mvk, self.mvs)
  55. self.assertEquals(get_inst(self.root, self.mvs), "constant")
  56. self.assertEquals(get_phase(self.root, self.mvs), "init")
  57. execute_until_finished(self.mvk, self.mvs)
  58. self.assertEquals(get_inst(self.root, self.mvs), "constant")
  59. self.assertEquals(get_phase(self.root, self.mvs), "finish")
  60. execute_until_finished(self.mvk, self.mvs)
  61. self.assertEquals(get_inst(self.root, self.mvs), "assign")
  62. self.assertEquals(get_phase(self.root, self.mvs), "assign")
  63. execute_until_finished(self.mvk, self.mvs)
  64. self.assertEquals(get_inst(self.root, self.mvs), "assign")
  65. self.assertEquals(get_phase(self.root, self.mvs), "finish")
  66. # Check if the new value is really assigned
  67. t = self.mvs.execute("RD", [self.root, "task_1"])[0]
  68. t = self.mvs.execute("RD", [t, "frame"])[0]
  69. t = self.mvs.execute("RD", [t, "symbols"])[0]
  70. t = self.mvs.execute("RDN", [t, self.var])[0]
  71. t = self.mvs.execute("RD", [t, "value"])[0]
  72. t = self.mvs.execute("RV", [t])[0]
  73. self.assertEquals(t, True)