test_pn_interface.py 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384
  1. import unittest
  2. from utils import run_file
  3. do_instantiate_simple = [
  4. "new", "PetriNets", "abc",
  5. "instantiate", "Transition", "t1",
  6. "instantiate", "Place", "p1", "attr_add", "p1", "tokens", 5,
  7. "instantiate", "Place", "p2", "attr_add", "p2", "tokens", 0,
  8. "instantiate", "P2T", "p2t", "p1", "t1", "attr_add", "p2t", "weight", 2,
  9. "instantiate", "T2P", "t2p", "t1", "p2", "attr_add", "t2p", "weight", 1]
  10. instantiate_node = ["Type to instantiate?",
  11. "Name of new element?",
  12. "Instantiation successful!"]
  13. instantiate_edge = ["Type to instantiate?",
  14. "Name of new element?",
  15. "Source name?",
  16. "Destination name?",
  17. "Instantiation successful!"]
  18. all_files = [ "pn_interface.alc",
  19. "primitives.alc",
  20. "object_operations.alc",
  21. "conformance_scd.alc",
  22. "library.alc",
  23. "metamodels.alc",
  24. "--fast",
  25. ]
  26. greeting = ["Welcome to the Model Management Interface, running live on the Modelverse!",
  27. "Use 'help' command for a list of possible commands"]
  28. new = ["Metamodel to instantiate?",
  29. "Name of model?"]
  30. prompt = ["Please give your command."]
  31. loaded = ["Model loaded, ready for commands!",
  32. "Use 'help' command for a list of possible commands"] + prompt
  33. load = ["Model to load?"]
  34. instantiate = ["Type to instantiate?"]
  35. instantiate_name = ["Name of new element?"]
  36. instantiate_ok = ["Instantiation successful!"]
  37. instantiate_source= ["Source name?"]
  38. instantiate_destination = ["Destination name?"]
  39. def list_menu(defined):
  40. defined.append(("PetriNets", "SimpleClassDiagrams"))
  41. defined.append(("SimpleClassDiagrams", "SimpleClassDiagrams"))
  42. defined.append(("LTM_bottom", "LTM_bottom"))
  43. return ["Found models:",
  44. set([" %s : %s" % (m, mm) for m, mm in defined])]
  45. def list_model(defined):
  46. return ["List of all elements:",
  47. set([" %s : %s" % (m, mm) for m, mm in defined])]
  48. def read_node(name, t, defs, attrs):
  49. return ["Element to read?",
  50. "Name: %s" % name,
  51. "Type: %s" % t,
  52. "Defines attributes:"] + \
  53. ([set([" %s : %s" % (m, mm) for m, mm in defs])] if defs else []) + \
  54. ["Attributes:"] + \
  55. ([set([' "%s" : "%s" = %s' % (m, mm, v) for m, mm, v in attrs])] if attrs else [])
  56. def read_edge(name, t, src, dst, defs, attrs):
  57. return ["Element to read?",
  58. "Name: %s" % name,
  59. "Type: %s" % t,
  60. "Source: %s" % src,
  61. "Destination: %s" % dst,
  62. "Defines attributes:"] + \
  63. ([set([" %s : %s" % (m, mm) for m, mm in defs])] if defs else []) + \
  64. ["Attributes:"] + \
  65. ([set([' "%s" : "%s" = %s' % (m, mm, v) for m, mm, v in attrs])] if attrs else [])
  66. def enabled(enableds):
  67. return ["Enabled transitions:"] + \
  68. [set(enableds)]
  69. def fire(fired):
  70. return ["Transition to fire?"] + \
  71. [set([" %s: %s" % (p, v) for p, v in fired])] + \
  72. ["Transition fired!"]
  73. delete = ["Model to delete?", "Deleted!"]
  74. rename = ["Old name?", "New name?", "Rename complete!"]
  75. attr_add = ["Which model do you want to assign an attribute to?",
  76. "Which attribute do you wish to assign?",
  77. "Value of attribute?",
  78. "Added attribute!"]
  79. attr_del = ["Which model do you want to remove an attribute of?",
  80. "Which attribute do you want to delete?",
  81. "Attribute deleted!",
  82. ]
  83. help_root = ["Currently no model is loaded, so your operations are limited to:",
  84. " new -- Create a new model and save it for future use"
  85. " load -- Load a previously made model",
  86. " rename -- Rename a previously made model",
  87. " delete -- Delete a previously made model",
  88. " list -- Show a list of all stored models",
  89. " help -- Show a list of possible commands"]
  90. verify_fail_weight= ["Negative weight in arc p2t"]
  91. verify_fail_tokens= ["Negative number of tokens in Place p1"]
  92. verify_fail_structure = ["Source of model edge not typed by source of type: p2t"]
  93. init = greeting + prompt
  94. did_instantiate_simple = init + \
  95. new + \
  96. loaded +\
  97. instantiate_node + \
  98. prompt + \
  99. instantiate_node + \
  100. prompt + \
  101. attr_add + \
  102. prompt + \
  103. instantiate_node + \
  104. prompt + \
  105. attr_add + \
  106. prompt + \
  107. instantiate_edge + \
  108. prompt + \
  109. attr_add + \
  110. prompt + \
  111. instantiate_edge + \
  112. prompt + \
  113. attr_add + \
  114. prompt
  115. def list_types(t):
  116. return ["List of types:"] + \
  117. [set([" %s : %s" % (m, mm) for m, mm in t])]
  118. modify = ["Element to modify?",
  119. "Attribute to modify?",
  120. "New value?",
  121. "Modified!",]
  122. class TestPetrinetInterface(unittest.TestCase):
  123. def test_po_pn_interface_manage(self):
  124. self.pn_interface_manage("PO")
  125. def test_co_pn_interface_manage(self):
  126. self.pn_interface_manage("CO")
  127. def pn_interface_manage(self, mode):
  128. self.assertTrue(run_file(all_files,
  129. ["list",
  130. "new", "PetriNets", "abc", "exit",
  131. "list",
  132. "new", "PetriNets", "def", "exit",
  133. "list",
  134. "delete", "def",
  135. "list",
  136. "rename", "abc", "a",
  137. "list",
  138. "delete", "a",
  139. "list",
  140. ],
  141. init + \
  142. list_menu([]) + prompt + \
  143. new + loaded + prompt + list_menu([("abc", "PetriNets")]) + prompt + \
  144. new + loaded + prompt + list_menu([("abc", "PetriNets"), ("def", "PetriNets")]) + prompt + \
  145. delete + prompt + list_menu([("abc", "PetriNets")]) + prompt + \
  146. rename + prompt + list_menu([("a", "PetriNets")]) + prompt + \
  147. delete + prompt + list_menu([]) + prompt,
  148. mode))
  149. def test_po_pn_interface_new_reload(self):
  150. self.pn_interface_new_reload("PO")
  151. def test_co_pn_interface_new_reload(self):
  152. self.pn_interface_new_reload("CO")
  153. def pn_interface_new_reload(self, mode):
  154. self.assertTrue(run_file(all_files,
  155. ["new", "PetriNets", "abc", "exit", "load", "abc"],
  156. init + new + loaded + prompt + load + loaded,
  157. mode))
  158. def test_po_pn_interface_instantiate_place(self):
  159. self.pn_interface_instantiate_place("PO")
  160. def test_co_pn_interface_instantiate_place(self):
  161. self.pn_interface_instantiate_place("CO")
  162. def pn_interface_instantiate_place(self, mode):
  163. self.assertTrue(run_file(all_files,
  164. ["new", "PetriNets", "abc",
  165. "instantiate", "Place", "p1",
  166. "attr_add", "p1", "tokens", 5,
  167. "list",
  168. "read", "p1",
  169. "instantiate", "Transition", "t1",
  170. "list",
  171. "read", "t1"],
  172. init + new + loaded + \
  173. instantiate_node + prompt + \
  174. attr_add + prompt + \
  175. list_model([("p1", "Place")]) + prompt + \
  176. read_node("p1", "Place", [], [("tokens", "Integer", 5)]) + prompt + \
  177. instantiate_node + prompt + \
  178. list_model([("p1", "Place"), ("t1", "Transition")]) + prompt + \
  179. read_node("t1", "Transition", [], []) + prompt,
  180. mode))
  181. def test_po_pn_interface_instantiate_arcs(self):
  182. self.pn_interface_instantiate_arcs("PO")
  183. def test_co_pn_interface_instantiate_arcs(self):
  184. self.pn_interface_instantiate_arcs("CO")
  185. def pn_interface_instantiate_arcs(self, mode):
  186. self.assertTrue(run_file(all_files,
  187. do_instantiate_simple + [
  188. "read", "p1",
  189. "read", "p2",
  190. "read", "t1",
  191. "read", "p2t",
  192. "read", "t2p",
  193. ],
  194. did_instantiate_simple + \
  195. read_node("p1", "Place", [], [("tokens", "Integer", 5)]) + prompt + \
  196. read_node("p2", "Place", [], [("tokens", "Integer", 0)]) + prompt + \
  197. read_node("t1", "Transition", [], []) + prompt + \
  198. read_edge("p2t", "P2T", "p1", "t1", [], [("weight", "Integer", 2)]) + prompt + \
  199. read_edge("t2p", "T2P", "t1", "p2", [], [("weight", "Integer", 1)]) + prompt,
  200. mode))
  201. def test_po_pn_interface_enabled(self):
  202. self.pn_interface_enabled("PO")
  203. def test_co_pn_interface_enabled(self):
  204. self.pn_interface_enabled("CO")
  205. def pn_interface_enabled(self, mode):
  206. self.assertTrue(run_file(all_files,
  207. do_instantiate_simple + ["enabled"],
  208. did_instantiate_simple + enabled(["t1"]) + prompt,
  209. mode))
  210. def test_po_pn_interface_fire(self):
  211. self.pn_interface_fire("PO")
  212. def test_co_pn_interface_fire(self):
  213. self.pn_interface_fire("CO")
  214. def pn_interface_fire(self, mode):
  215. self.assertTrue(run_file(all_files,
  216. do_instantiate_simple + ["fire", "t1"],
  217. did_instantiate_simple + fire([("p1", 3), ("p2", 1)]) + prompt,
  218. mode))
  219. def test_po_pn_interface_verify_OK(self):
  220. self.pn_interface_verify_OK("PO")
  221. def test_co_pn_interface_verify_OK(self):
  222. self.pn_interface_verify_OK("CO")
  223. def pn_interface_verify_OK(self, mode):
  224. self.assertTrue(run_file(all_files,
  225. do_instantiate_simple + ["verify"],
  226. did_instantiate_simple + ["OK"], mode))
  227. def test_po_pn_interface_verify_fail_tokens(self):
  228. self.pn_interface_verify_fail_tokens("PO")
  229. def test_co_pn_interface_verify_fail_tokens(self):
  230. self.pn_interface_verify_fail_tokens("CO")
  231. def pn_interface_verify_fail_tokens(self, mode):
  232. self.assertTrue(run_file(all_files,
  233. do_instantiate_simple + ["modify", "p1", "tokens", -5, "verify"],
  234. did_instantiate_simple + modify + prompt + verify_fail_tokens + prompt, mode))
  235. def test_po_pn_interface_verify_fail_weight(self):
  236. self.pn_interface_verify_fail_weight("PO")
  237. def test_co_pn_interface_verify_fail_weight(self):
  238. self.pn_interface_verify_fail_weight("CO")
  239. def pn_interface_verify_fail_weight(self, mode):
  240. self.assertTrue(run_file(all_files,
  241. do_instantiate_simple + ["modify", "p2t", "weight", -2, "verify"],
  242. did_instantiate_simple + modify + prompt + verify_fail_weight + prompt, mode))
  243. def test_po_pn_interface_verify_fail_structure(self):
  244. self.pn_interface_verify_fail_structure("PO")
  245. def test_co_pn_interface_verify_fail_structure(self):
  246. self.pn_interface_verify_fail_structure("CO")
  247. def pn_interface_verify_fail_structure(self, mode):
  248. self.assertTrue(run_file(all_files,
  249. ["new", "PetriNets", "abc",
  250. "instantiate", "Transition", "t1",
  251. "instantiate", "Place", "p1", "attr_add", "p1", "tokens", 5,
  252. "instantiate", "P2T", "p2t", "t1", "p1", "attr_add", "p2t", "weight", 2, "verify"],
  253. init + new + loaded + \
  254. instantiate_node + prompt + \
  255. instantiate_node + prompt + attr_add + prompt + \
  256. instantiate_edge + prompt + attr_add + prompt + \
  257. verify_fail_structure,
  258. mode))
  259. def test_po_pn_interface_types(self):
  260. self.pn_interface_types("PO")
  261. def test_co_pn_interface_types(self):
  262. self.pn_interface_types("CO")
  263. def pn_interface_types(self, mode):
  264. self.assertTrue(run_file(all_files,
  265. ["new", "PetriNets", "abc", "types"],
  266. init + new + loaded + list_types([("Place", "Class"), ("Transition", "Class"), ("P2T", "Association"), ("T2P", "Association"), ("Integer", "Class")]),
  267. mode))
  268. def test_po_pn_interface_modify_place(self):
  269. self.pn_interface_modify_place("PO")
  270. def test_co_pn_interface_modify_place(self):
  271. self.pn_interface_modify_place("CO")
  272. def pn_interface_modify_place(self, mode):
  273. self.assertTrue(run_file(all_files,
  274. ["new", "PetriNets", "abc",
  275. "instantiate", "Place", "p1", "attr_add", "p1", "tokens", 5,
  276. "read", "p1",
  277. "modify", "p1", "tokens", 1, "read", "p1"],
  278. init + new + loaded + \
  279. instantiate_node + prompt + attr_add + prompt + \
  280. read_node("p1", "Place", [], [("tokens", "Integer", 5)]) + prompt + \
  281. modify + prompt + \
  282. read_node("p1", "Place", [], [("tokens", "Integer", 1)]) + prompt,
  283. mode))
  284. def test_po_pn_interface_verify_fail_attr_lower_cardinality(self):
  285. self.pn_interface_verify_fail_attr_lower_cardinality("PO")
  286. def test_co_pn_interface_verify_fail_attr_lower_cardinality(self):
  287. self.pn_interface_verify_fail_attr_lower_cardinality("CO")
  288. def pn_interface_verify_fail_attr_lower_cardinality(self, mode):
  289. self.assertTrue(run_file(all_files,
  290. do_instantiate_simple + ["instantiate", "Place", "p999", "verify"],
  291. did_instantiate_simple + instantiate_node + prompt + ["Lower cardinality violation for outgoing edge at p999"] + prompt,
  292. mode))
  293. def test_po_pn_interface_verify_fail_attr_upper_cardinality(self):
  294. self.pn_interface_verify_fail_attr_upper_cardinality("PO")
  295. def test_co_pn_interface_verify_fail_attr_upper_cardinality(self):
  296. self.pn_interface_verify_fail_attr_upper_cardinality("CO")
  297. def pn_interface_verify_fail_attr_upper_cardinality(self, mode):
  298. self.assertTrue(run_file(all_files,
  299. do_instantiate_simple + ["attr_add", "p1", "tokens", 5, "verify"],
  300. did_instantiate_simple + attr_add + prompt + ["Upper cardinality violation for outgoing edge at p1"] + prompt,
  301. mode))
  302. def test_po_pn_interface_verify_natural(self):
  303. self.pn_interface_verify_natural("PO")
  304. def test_co_pn_interface_verify_natural(self):
  305. self.pn_interface_verify_natural("CO")
  306. def pn_interface_verify_natural(self, mode):
  307. self.assertTrue(run_file(all_files,
  308. ["new", "PetriNets", "abc",
  309. "instantiate", "Place", "p1",
  310. "attr_add", "p1", "tokens", -5,
  311. "attr_del", "p1", "tokens",
  312. "attr_add", "p1", "tokens", 4,
  313. "verify"],
  314. init + new + loaded + \
  315. instantiate_node + prompt + \
  316. attr_add + prompt + \
  317. attr_del + prompt + \
  318. attr_add + prompt + \
  319. ["OK"] + prompt,
  320. mode))