test_instruction_declare.py 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. import unittest
  2. from modelverse_kernel.main import ModelverseKernel
  3. from utils import execute_until_finished, MvSWrapper, get_inst, get_phase, get_returnvalue
  4. class TestDeclare(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.user_root = self.mvs.execute("CN", [])[0]
  10. self.globals = self.mvs.execute("CN", [])[0]
  11. self.user_frame = self.mvs.execute("CN", [])[0]
  12. self.symbols = self.mvs.execute("CN", [])[0]
  13. self.evalstack = self.mvs.execute("CN", [])[0]
  14. self.returnvalue = self.mvs.execute("CN", [])[0]
  15. self.phase = self.mvs.execute("CNV", ["init"])[0]
  16. self.mvs.execute("CD", [self.root, "user_1", self.user_root])
  17. self.mvs.execute("CD", [self.user_root, "frame", self.user_frame])
  18. self.mvs.execute("CD", [self.user_root, "globals", self.globals])
  19. self.mvs.execute("CD", [self.user_frame, "symbols", self.symbols])
  20. self.mvs.execute("CD", [self.user_frame, "evalstack", self.evalstack])
  21. self.mvs.execute("CD", [self.user_frame, "phase", self.phase])
  22. self.mvs.execute("CD", [self.user_frame, "returnvalue", self.returnvalue])
  23. def test_declare(self):
  24. self.inst = self.mvs.execute("CNV", [{"value":"declare"}])[0]
  25. self.var = self.mvs.execute("CN", [])[0]
  26. self.mvs.execute("CD", [self.user_frame, "IP", self.inst])
  27. self.mvs.execute("CD", [self.inst, "var", self.var])
  28. ### Execute rules
  29. self.assertEquals(get_inst(self.root, self.mvs), "declare")
  30. self.assertEquals(get_phase(self.root, self.mvs), "init")
  31. execute_until_finished(self.mvk, self.mvs)
  32. self.assertEquals(get_inst(self.root, self.mvs), "declare")
  33. self.assertEquals(get_phase(self.root, self.mvs), "finish")
  34. self.assertNotEquals(self.mvs.execute("RDN", [self.symbols, self.var])[0], None)
  35. def test_global(self):
  36. self.global_symbols = self.mvs.execute("RD", [self.user_root, "globals"])[0]
  37. self.inst = self.mvs.execute("CNV", [{"value":"global"}])[0]
  38. self.var = self.mvs.execute("CNV", ["abc"])[0]
  39. self.mvs.execute("CD", [self.user_frame, "IP", self.inst])
  40. self.mvs.execute("CD", [self.inst, "var", self.var])
  41. ### Execute rules
  42. self.assertEquals(get_inst(self.root, self.mvs), "global")
  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), "global")
  46. self.assertEquals(get_phase(self.root, self.mvs), "finish")
  47. self.assertNotEquals(self.mvs.execute("RD", [self.global_symbols, "abc"])[0], None)