test_pn_interface.py 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663
  1. import unittest
  2. from utils import run_file
  3. all_files = [ "pn_interface.alc",
  4. "primitives.alc",
  5. "object_operations.alc",
  6. "conformance_scd.alc",
  7. "library.alc",
  8. "constructors.alc",
  9. "--fast",
  10. ]
  11. greeting = ["Welcome to the Model Management Interface, running live"
  12. " on the Modelverse!",
  13. "Use 'help' command for a list of possible commands"]
  14. new = ["Metamodel to instantiate?", "Name of model?"]
  15. new_fail = ["Model exists; aborting"]
  16. loaded = ["Model loaded, ready for commands!",
  17. "Use 'help' command for a list of possible commands"]
  18. prompt_menu = ["Please give your command."]
  19. prompt_model = ["Please give your command."]
  20. load = ["Model to load?"]
  21. load_fail = ["Model not found; aborting"]
  22. instantiate = ["Type to instantiate?"]
  23. instantiate_name = ["Name of new element?"]
  24. instantiate_tokens= ["tokens : Integer?"]
  25. instantiate_ok = ["Instantiation successful!"]
  26. instantiate_source= ["Source name?"]
  27. instantiate_destination = ["Destination name?"]
  28. instantiate_weight= ["weight : Integer?"]
  29. list_menu = ["Found models:"]
  30. list_all = set([" PetriNets : SimpleClassDiagrams",
  31. " SimpleClassDiagrams : SimpleClassDiagrams",
  32. " LTM_bottom : LTM_bottom"])
  33. list_empty = list_menu + [list_all]
  34. list_abc = [" abc : PetriNets"]
  35. list_def = [" def : PetriNets"]
  36. list_model = ["List of all elements:"]
  37. list_p1 = [" p1 : Place"]
  38. list_p2 = [" p2 : Place"]
  39. list_t1 = [" t1 : Transition"]
  40. list_p2t = [" p2t : P2T"]
  41. list_t2p = [" t2p : T2P"]
  42. read = ["Element to read?"]
  43. read_p1 = ["Name: p1",
  44. "Type: Place",
  45. "Defines attributes:",
  46. "Attributes:",
  47. " tokens : Integer = 5"]
  48. read_p1_1 = ["Name: p1",
  49. "Type: Place",
  50. "Defines attributes:",
  51. "Attributes:",
  52. " tokens : Integer = 1"]
  53. read_p2 = ["Name: p2",
  54. "Type: Place",
  55. "Defines attributes:",
  56. "Attributes:",
  57. " tokens : Integer = 0"]
  58. read_t1 = ["Name: t1",
  59. "Type: Transition",
  60. "Defines attributes:",
  61. "Attributes:"]
  62. read_p2t = ["Name: p2t",
  63. "Type: P2T",
  64. "Source: p1",
  65. "Destination: t1",
  66. "Defines attributes:",
  67. "Attributes:",
  68. " weight : Integer = 2"]
  69. read_t2p = ["Name: t2p",
  70. "Type: T2P",
  71. "Source: t1",
  72. "Destination: p2",
  73. "Defines attributes:",
  74. "Attributes:",
  75. " weight : Integer = 1"]
  76. read_fail = ["Unknown element; aborting"]
  77. enabled = ["Enabled transitions:"]
  78. enabled_t1 = ["t1"]
  79. fire = ["Transition to fire?"]
  80. fire_t1 = [" p1: 3",
  81. " p2: 1"]
  82. fire_finish = ["Transition fired!"]
  83. fire_unknown = ["Unknown transition; aborting"]
  84. fire_no_enable = ["Cannot fire if not enabled; aborting"]
  85. delete = ["Model to delete?"]
  86. delete_ok = ["Deleted!"]
  87. delete_fail = ["Model not found; aborting"]
  88. rename_old = ["Old name?"]
  89. rename_new = ["New name?"]
  90. rename_ok = ["Rename complete!"]
  91. rename_fail_not_exists = ["Model not found; aborting"]
  92. rename_fail_exists= ["Model exists; aborting"]
  93. rename_model_old = ["Old name?"]
  94. rename_model_new = ["New name?"]
  95. rename_model_ok = ["Rename complete!"]
  96. rename_model_fail_not_exists = ["Unknown element; aborting"]
  97. rename_model_fail_exists= ["New name already used; aborting"]
  98. help_msg = ["Currently no model is loaded, so your operations are "
  99. "limited to:",
  100. " new -- Create a new model and save it for future "
  101. "use",
  102. " load -- Load a previously made model",
  103. " rename -- Rename a previously made model",
  104. " delete -- Delete a previously made model",
  105. " list -- Show a list of all stored models",
  106. " help -- Show a list of possible commands"]
  107. verify_ok = ["OK"]
  108. verify_fail_weight= ["Negative weight in arc p2t"]
  109. verify_fail_tokens= ["Negative number of tokens in Place p1"]
  110. verify_fail_structure = ["Source of model edge not typed by source of type: "
  111. "p2t"]
  112. list_types = ["List of types:",
  113. " Place : Class",
  114. " Transition : Class",
  115. " P2T : Association",
  116. " T2P : Association"]
  117. modify = ["Element to modify?"]
  118. modify_place = [" tokens : Integer"]
  119. modify_arc = [" weight : Integer"]
  120. modify_attribute = ["Attribute to modify?"]
  121. modify_value = ["New value?",
  122. "Modified!"]
  123. modify_fail_not_exists = ["Element does not exist; aborting"]
  124. modify_fail_no_attr=["Unknown attribute; aborting"]
  125. instantiate_place = instantiate + instantiate_name + instantiate_tokens +\
  126. instantiate_ok + prompt_model
  127. instantiate_transition = instantiate + instantiate_name + instantiate_ok +\
  128. prompt_model
  129. instantiate_arc = instantiate + instantiate_name + instantiate_source +\
  130. instantiate_destination + instantiate_weight +\
  131. instantiate_ok + prompt_model
  132. read_p1_full = read + read_p1 + prompt_model
  133. read_p2_full = read + read_p2 + prompt_model
  134. read_p1_as_p2 = read + [v.replace("p1", "p2") for v in read_p1] + prompt_model
  135. read_t1_full = read + read_t1 + prompt_model
  136. read_p2t_full = read + read_p2t + prompt_model
  137. read_t2p_full = read + read_t2p + prompt_model
  138. new_full = new + loaded + prompt_model
  139. delete_full = delete + delete_ok + prompt_menu
  140. init = greeting + prompt_menu
  141. rename_full = rename_old + rename_new + rename_ok + prompt_menu
  142. rename_model_full = rename_model_old + rename_model_new + rename_model_ok +\
  143. prompt_model
  144. help_full = help_msg + prompt_menu
  145. load_full = load + loaded + prompt_model
  146. verify_full = verify_ok + prompt_model
  147. types_full = list_types + prompt_model
  148. modify_place_full = modify + modify_place + modify_attribute + modify_value +\
  149. prompt_model
  150. class TestPetrinetInterface(unittest.TestCase):
  151. def test_po_pn_interface_new(self):
  152. self.pn_interface_new("PO")
  153. def test_co_pn_interface_new(self):
  154. self.pn_interface_new("CO")
  155. def pn_interface_new(self, mode):
  156. self.assertTrue(run_file(all_files, ["help", "new", "PetriNets", "abc"],
  157. init + help_full + new_full, mode))
  158. def test_po_pn_interface_list_empty(self):
  159. self.pn_interface_list_empty("PO")
  160. def test_co_pn_interface_list_empty(self):
  161. self.pn_interface_list_empty("CO")
  162. def pn_interface_list_empty(self, mode):
  163. self.assertTrue(run_file(all_files, ["list"],
  164. init + list_empty + prompt_model, mode))
  165. def test_po_pn_interface_list_one(self):
  166. self.pn_interface_list_one("PO")
  167. def test_co_pn_interface_list_one(self):
  168. self.pn_interface_list_one("CO")
  169. def pn_interface_list_one(self, mode):
  170. self.assertTrue(run_file(all_files,
  171. ["new", "PetriNets", "abc", "exit", "list"], init + new_full + prompt_menu +
  172. list_menu + [set(list_abc).union(list_all)] + prompt_menu, mode))
  173. def test_po_pn_interface_list_two(self):
  174. self.pn_interface_list_two("PO")
  175. def test_co_pn_interface_list_two(self):
  176. self.pn_interface_list_two("CO")
  177. def pn_interface_list_two(self, mode):
  178. self.assertTrue(run_file(all_files,
  179. ["new", "PetriNets", "abc", "exit", "new", "PetriNets", "def", "exit", "list"],
  180. init + new_full + prompt_menu + new_full + prompt_menu +
  181. list_menu + [set(list_abc).union(set(list_def)).union(list_all)] + prompt_menu, mode))
  182. def test_po_pn_interface_rename(self):
  183. self.pn_interface_rename("PO")
  184. def test_co_pn_interface_rename(self):
  185. self.pn_interface_rename("CO")
  186. def pn_interface_rename(self, mode):
  187. self.assertTrue(run_file(all_files,
  188. ["new", "PetriNets", "abc", "exit", "list", "rename", "abc", "def", "list",
  189. "load", "abc", "load", "def", "exit", "list"],
  190. init + new_full + prompt_menu + list_menu + [set(list_abc).union(list_all)] +
  191. prompt_menu + rename_full + list_menu + [set(list_def).union(list_all)] + prompt_menu +
  192. load + load_fail + prompt_menu + load_full + prompt_menu +
  193. list_menu + [set(list_def).union(list_all)] + prompt_menu, mode))
  194. def test_po_pn_interface_rename_fail_not_exists(self):
  195. self.pn_interface_rename_fail_not_exists("PO")
  196. def test_co_pn_interface_rename_fail_not_exists(self):
  197. self.pn_interface_rename_fail_not_exists("CO")
  198. def pn_interface_rename_fail_not_exists(self, mode):
  199. self.assertTrue(run_file(all_files,
  200. ["new", "PetriNets", "abc", "exit", "list", "rename", "def", "list", "load",
  201. "abc", "exit", "load", "def", "list"],
  202. init + new_full + prompt_menu + list_menu + [set(list_abc).union(list_all)] +
  203. prompt_menu + rename_old + rename_fail_not_exists + prompt_menu +
  204. list_menu + [set(list_abc).union(list_all)] + prompt_menu + load_full + prompt_menu +
  205. load + load_fail + prompt_menu + list_menu + [set(list_abc).union(list_all)] +
  206. prompt_menu, mode))
  207. def test_po_pn_interface_delete_only(self):
  208. self.pn_interface_delete_only("PO")
  209. def test_co_pn_interface_delete_only(self):
  210. self.pn_interface_delete_only("CO")
  211. def pn_interface_delete_only(self, mode):
  212. self.assertTrue(run_file(all_files,
  213. ["new", "PetriNets", "abc", "exit", "delete", "abc", "list"],
  214. init + new_full + prompt_menu + delete_full + list_empty +
  215. prompt_menu, mode))
  216. def test_po_pn_interface_delete(self):
  217. self.pn_interface_delete("PO")
  218. def test_co_pn_interface_delete(self):
  219. self.pn_interface_delete("CO")
  220. def pn_interface_delete(self, mode):
  221. self.assertTrue(run_file(all_files,
  222. ["new", "PetriNets", "abc", "exit", "new", "PetriNets", "def", "exit", "delete", "abc",
  223. "list"], init + new_full + prompt_menu + new_full + prompt_menu +
  224. delete_full + list_menu + [set(list_def).union(list_all)] + prompt_menu, mode))
  225. def test_po_pn_interface_delete_fail(self):
  226. self.pn_interface_delete_fail("PO")
  227. def test_co_pn_interface_delete_fail(self):
  228. self.pn_interface_delete_fail("CO")
  229. def pn_interface_delete_fail(self, mode):
  230. self.assertTrue(run_file(all_files,
  231. ["new", "PetriNets", "abc", "exit", "delete", "def", "list"],
  232. init + new_full + prompt_menu + delete + delete_fail +
  233. prompt_menu + list_menu + [set(list_abc).union(list_all)] + prompt_menu, mode))
  234. def test_po_pn_interface_new_reload(self):
  235. self.pn_interface_new_reload("PO")
  236. def test_co_pn_interface_new_reload(self):
  237. self.pn_interface_new_reload("CO")
  238. def pn_interface_new_reload(self, mode):
  239. self.assertTrue(run_file(all_files,
  240. ["new", "PetriNets", "abc", "exit", "load", "abc"], init + new_full +
  241. prompt_menu + load_full, mode))
  242. def test_po_pn_interface_new_fail(self):
  243. self.pn_interface_new_fail("PO")
  244. def test_co_pn_interface_new_fail(self):
  245. self.pn_interface_new_fail("CO")
  246. def pn_interface_new_fail(self, mode):
  247. self.assertTrue(run_file(all_files,
  248. ["new", "PetriNets", "abc", "exit", "new", "PetriNets", "abc"], init + new_full +
  249. prompt_menu + new + new_fail + prompt_menu, mode))
  250. def test_po_pn_interface_load_fail(self):
  251. self.pn_interface_load_fail("PO")
  252. def test_co_pn_interface_load_fail(self):
  253. self.pn_interface_load_fail("CO")
  254. def pn_interface_load_fail(self, mode):
  255. self.assertTrue(run_file(all_files,
  256. ["new", "PetriNets", "abc", "exit", "load", "def"], init + new_full +
  257. prompt_menu + load + load_fail + prompt_menu, mode))
  258. def test_po_pn_interface_load_empty(self):
  259. self.pn_interface_load_empty("PO")
  260. def test_co_pn_interface_load_empty(self):
  261. self.pn_interface_load_empty("CO")
  262. def pn_interface_load_empty(self, mode):
  263. self.assertTrue(run_file(all_files,
  264. ["load", "def"], init + load + load_fail + prompt_menu, mode))
  265. def test_po_pn_interface_new_list_empty(self):
  266. self.pn_interface_new_list_empty("PO")
  267. def test_co_pn_interface_new_list_empty(self):
  268. self.pn_interface_new_list_empty("CO")
  269. def pn_interface_new_list_empty(self, mode):
  270. self.assertTrue(run_file(all_files,
  271. ["new", "PetriNets", "abc", "list"], init + new_full + list_model +
  272. prompt_model, mode))
  273. def test_po_pn_interface_instantiate_place(self):
  274. self.pn_interface_instantiate_place("PO")
  275. def test_co_pn_interface_instantiate_place(self):
  276. self.pn_interface_instantiate_place("CO")
  277. def pn_interface_instantiate_place(self, mode):
  278. self.assertTrue(run_file(all_files,
  279. ["new", "PetriNets", "abc", "instantiate", "Place", "p1", 5],
  280. init + new_full + instantiate + instantiate_name +
  281. instantiate_tokens + instantiate_ok + prompt_model, mode))
  282. def test_po_pn_interface_instantiate_place_list(self):
  283. self.pn_interface_instantiate_place_list("PO")
  284. def test_co_pn_interface_instantiate_place_list(self):
  285. self.pn_interface_instantiate_place_list("CO")
  286. def pn_interface_instantiate_place_list(self, mode):
  287. self.assertTrue(run_file(all_files,
  288. ["new", "PetriNets", "abc", "instantiate", "Place", "p1", 5, "list"],
  289. init + new_full + instantiate + instantiate_name +
  290. instantiate_tokens + instantiate_ok + prompt_model +
  291. list_model + list_p1, mode))
  292. def test_po_pn_interface_instantiate_place_read(self):
  293. self.pn_interface_instantiate_place_read("PO")
  294. def test_co_pn_interface_instantiate_place_read(self):
  295. self.pn_interface_instantiate_place_read("CO")
  296. def pn_interface_instantiate_place_read(self, mode):
  297. self.assertTrue(run_file(all_files,
  298. ["new", "PetriNets", "abc", "instantiate", "Place", "p1", 5, "read", "p1"],
  299. init + new_full + instantiate + instantiate_name +
  300. instantiate_tokens + instantiate_ok + prompt_model + read +
  301. read_p1, mode))
  302. def test_po_pn_interface_instantiate_transition(self):
  303. self.pn_interface_instantiate_transition("PO")
  304. def test_co_pn_interface_instantiate_transition(self):
  305. self.pn_interface_instantiate_transition("CO")
  306. def pn_interface_instantiate_transition(self, mode):
  307. self.assertTrue(run_file(all_files,
  308. ["new", "PetriNets", "abc", "instantiate", "Transition", "t1"],
  309. init + new_full + instantiate + instantiate_name +
  310. instantiate_ok + prompt_model, mode))
  311. def test_po_pn_interface_instantiate_transition_read(self):
  312. self.pn_interface_instantiate_transition_read("PO")
  313. def test_co_pn_interface_instantiate_transition_read(self):
  314. self.pn_interface_instantiate_transition_read("CO")
  315. def pn_interface_instantiate_transition_read(self, mode):
  316. self.assertTrue(run_file(all_files,
  317. ["new", "PetriNets", "abc", "instantiate", "Transition", "t1", "read", "t1"],
  318. init + new_full + instantiate + instantiate_name +
  319. instantiate_ok + prompt_model + read + read_t1, mode))
  320. def test_po_pn_interface_instantiate_arcs(self):
  321. self.pn_interface_instantiate_arcs("PO")
  322. def test_co_pn_interface_instantiate_arcs(self):
  323. self.pn_interface_instantiate_arcs("CO")
  324. def pn_interface_instantiate_arcs(self, mode):
  325. self.assertTrue(run_file(all_files,
  326. ["new", "PetriNets", "abc", "instantiate", "Transition", "t1", "instantiate",
  327. "Place", "p1", 5, "instantiate", "Place", "p2", 0, "instantiate",
  328. "P2T", "p2t", "p1", "t1", 2, "instantiate", "T2P", "t2p", "t1",
  329. "p2", 1],
  330. init + new_full + instantiate_transition + instantiate_place +
  331. instantiate_place + instantiate_arc + instantiate_arc, mode))
  332. def test_po_pn_interface_instantiate_arcs_read(self):
  333. self.pn_interface_instantiate_arcs_read("PO")
  334. def test_co_pn_interface_instantiate_arcs_read(self):
  335. self.pn_interface_instantiate_arcs_read("CO")
  336. def pn_interface_instantiate_arcs_read(self, mode):
  337. self.assertTrue(run_file(all_files,
  338. ["new", "PetriNets", "abc", "instantiate", "Transition", "t1", "instantiate",
  339. "Place", "p1", 5, "instantiate", "Place", "p2", 0, "instantiate",
  340. "P2T", "p2t", "p1", "t1", 2, "instantiate", "T2P", "t2p", "t1",
  341. "p2", 1, "read", "p1", "read", "p2", "read", "t1", "read", "p2t",
  342. "read", "t2p"],
  343. init + new_full + instantiate_transition + instantiate_place +
  344. instantiate_place + instantiate_arc + instantiate_arc +
  345. read_p1_full + read_p2_full + read_t1_full + read_p2t_full +
  346. read_t2p_full, mode))
  347. def test_po_pn_interface_instantiate_arcs_list(self):
  348. self.pn_interface_instantiate_arcs_list("PO")
  349. def test_co_pn_interface_instantiate_arcs_list(self):
  350. self.pn_interface_instantiate_arcs_list("CO")
  351. def pn_interface_instantiate_arcs_list(self, mode):
  352. self.assertTrue(run_file(all_files,
  353. ["new", "PetriNets", "abc", "instantiate", "Transition", "t1", "instantiate",
  354. "Place", "p1", 5, "instantiate", "Place", "p2", 0, "instantiate",
  355. "P2T", "p2t", "p1", "t1", 2, "instantiate", "T2P", "t2p", "t1",
  356. "p2", 1, "list"],
  357. init + new_full + instantiate_transition + instantiate_place +
  358. instantiate_place + instantiate_arc + instantiate_arc +
  359. list_model + list_t1 + list_p1 + list_p2 + list_p2t + list_t2p +
  360. prompt_model, mode))
  361. def test_po_pn_interface_enabled_empty(self):
  362. self.pn_interface_enabled_empty("PO")
  363. def test_co_pn_interface_enabled_empty(self):
  364. self.pn_interface_enabled_empty("CO")
  365. def pn_interface_enabled_empty(self, mode):
  366. self.assertTrue(run_file(all_files,
  367. ["new", "PetriNets", "abc", "enabled"],
  368. init + new_full + enabled + prompt_model, mode))
  369. def test_po_pn_interface_enabled(self):
  370. self.pn_interface_enabled("PO")
  371. def test_co_pn_interface_enabled(self):
  372. self.pn_interface_enabled("CO")
  373. def pn_interface_enabled(self, mode):
  374. self.assertTrue(run_file(all_files,
  375. ["new", "PetriNets", "abc", "instantiate", "Transition", "t1", "instantiate",
  376. "Place", "p1", 5, "instantiate", "Place", "p2", 0, "instantiate",
  377. "P2T", "p2t", "p1", "t1", 2, "instantiate", "T2P", "t2p", "t1",
  378. "p2", 1, "enabled"],
  379. init + new_full + instantiate_transition + instantiate_place +
  380. instantiate_place + instantiate_arc + instantiate_arc + enabled +
  381. enabled_t1 + prompt_model, mode))
  382. def test_po_pn_interface_fire(self):
  383. self.pn_interface_fire("PO")
  384. def test_co_pn_interface_fire(self):
  385. self.pn_interface_fire("CO")
  386. def pn_interface_fire(self, mode):
  387. self.assertTrue(run_file(all_files,
  388. ["new", "PetriNets", "abc", "instantiate", "Transition", "t1", "instantiate",
  389. "Place", "p1", 5, "instantiate", "Place", "p2", 0, "instantiate",
  390. "P2T", "p2t", "p1", "t1", 2, "instantiate", "T2P", "t2p", "t1",
  391. "p2", 1, "fire", "t1"],
  392. init + new_full + instantiate_transition + instantiate_place +
  393. instantiate_place + instantiate_arc + instantiate_arc + fire +
  394. fire_t1 + fire_finish + prompt_model, mode))
  395. def test_po_pn_interface_fire_place(self):
  396. self.pn_interface_fire_place("PO")
  397. def test_co_pn_interface_fire_place(self):
  398. self.pn_interface_fire_place("CO")
  399. def pn_interface_fire_place(self, mode):
  400. self.assertTrue(run_file(all_files,
  401. ["new", "PetriNets", "abc", "instantiate", "Place", "p1", "5", "fire", "p1"],
  402. init + new_full + instantiate_place + fire + fire_no_enable +
  403. prompt_model, mode))
  404. def test_po_pn_interface_fire_unknown(self):
  405. self.pn_interface_fire_unknown("PO")
  406. def test_co_pn_interface_fire_unknown(self):
  407. self.pn_interface_fire_unknown("CO")
  408. def pn_interface_fire_unknown(self, mode):
  409. self.assertTrue(run_file(all_files,
  410. ["new", "PetriNets", "abc", "fire", "t1"],
  411. init + new_full + fire + fire_unknown + prompt_model, mode))
  412. def test_po_pn_interface_verify_OK(self):
  413. self.pn_interface_verify_OK("PO")
  414. def test_co_pn_interface_verify_OK(self):
  415. self.pn_interface_verify_OK("CO")
  416. def pn_interface_verify_OK(self, mode):
  417. self.assertTrue(run_file(all_files,
  418. ["new", "PetriNets", "abc", "instantiate", "Transition", "t1", "instantiate",
  419. "Place", "p1", 5, "instantiate", "Place", "p2", 0, "instantiate",
  420. "P2T", "p2t", "p1", "t1", 2, "instantiate", "T2P", "t2p", "t1",
  421. "p2", 1, "verify"],
  422. init + new_full + instantiate_transition + instantiate_place +
  423. instantiate_place + instantiate_arc + instantiate_arc +
  424. verify_full, mode))
  425. def test_po_pn_interface_verify_fail_tokens(self):
  426. self.pn_interface_verify_fail_tokens("PO")
  427. def test_co_pn_interface_verify_fail_tokens(self):
  428. self.pn_interface_verify_fail_tokens("CO")
  429. def pn_interface_verify_fail_tokens(self, mode):
  430. self.assertTrue(run_file(all_files,
  431. ["new", "PetriNets", "abc", "instantiate", "Transition", "t1", "instantiate",
  432. "Place", "p1", -5, "instantiate", "Place", "p2", 0,
  433. "instantiate", "P2T", "p2t", "p1", "t1", 2, "instantiate", "T2P",
  434. "t2p", "t1", "p2", 1, "verify"],
  435. init + new_full + instantiate_transition + instantiate_place +
  436. instantiate_place + instantiate_arc + instantiate_arc +
  437. verify_fail_tokens, mode))
  438. def test_po_pn_interface_verify_fail_weight(self):
  439. self.pn_interface_verify_fail_weight("PO")
  440. def test_co_pn_interface_verify_fail_weight(self):
  441. self.pn_interface_verify_fail_weight("CO")
  442. def pn_interface_verify_fail_weight(self, mode):
  443. self.assertTrue(run_file(all_files,
  444. ["new", "PetriNets", "abc", "instantiate", "Transition", "t1", "instantiate",
  445. "Place", "p1", 5, "instantiate", "Place", "p2", 0, "instantiate",
  446. "P2T", "p2t", "p1", "t1", -2, "instantiate", "T2P", "t2p", "t1",
  447. "p2", 1, "verify"], init + new_full + instantiate_transition +
  448. instantiate_place + instantiate_place + instantiate_arc +
  449. instantiate_arc + verify_fail_weight, mode))
  450. def test_po_pn_interface_verify_fail_structure(self):
  451. self.pn_interface_verify_fail_structure("PO")
  452. def test_co_pn_interface_verify_fail_structure(self):
  453. self.pn_interface_verify_fail_structure("CO")
  454. def pn_interface_verify_fail_structure(self, mode):
  455. self.assertTrue(run_file(all_files,
  456. ["new", "PetriNets", "abc", "instantiate", "Transition", "t1", "instantiate",
  457. "Place", "p1", 5, "instantiate", "Place", "p2", 0, "instantiate",
  458. "P2T", "p2t", "t1", "p1", 2, "verify"],
  459. init + new_full + instantiate_transition + instantiate_place +
  460. instantiate_place + instantiate_arc + verify_fail_structure,
  461. mode))
  462. def test_po_pn_interface_types(self):
  463. self.pn_interface_types("PO")
  464. def test_co_pn_interface_types(self):
  465. self.pn_interface_types("CO")
  466. def pn_interface_types(self, mode):
  467. self.assertTrue(run_file(all_files,
  468. ["new", "PetriNets", "abc", "types"], init + new_full + types_full, mode))
  469. def test_po_pn_interface_modify_place(self):
  470. self.pn_interface_modify_place("PO")
  471. def test_co_pn_interface_modify_place(self):
  472. self.pn_interface_modify_place("CO")
  473. def pn_interface_modify_place(self, mode):
  474. self.assertTrue(run_file(all_files,
  475. ["new", "PetriNets", "abc", "instantiate", "Place", "p1", 5, "read", "p1",
  476. "modify", "p1", "tokens", 1, "read", "p1"],
  477. init + new_full + instantiate + instantiate_name +
  478. instantiate_tokens + instantiate_ok + prompt_model + read +
  479. read_p1 + prompt_menu + modify_place_full + read + read_p1_1 +
  480. prompt_menu, mode))
  481. def test_po_pn_interface_modify_unknown(self):
  482. self.pn_interface_modify_unknown("PO")
  483. def test_co_pn_interface_modify_unknown(self):
  484. self.pn_interface_modify_unknown("CO")
  485. def pn_interface_modify_unknown(self, mode):
  486. self.assertTrue(run_file(all_files,
  487. ["new", "PetriNets", "abc", "modify", "p1"],
  488. init + new_full + modify + modify_fail_not_exists + prompt_model,
  489. mode))
  490. def test_po_pn_interface_modify_place_attr(self):
  491. self.pn_interface_modify_place_attr("PO")
  492. def test_co_pn_interface_modify_place_attr(self):
  493. self.pn_interface_modify_place_attr("CO")
  494. def pn_interface_modify_place_attr(self, mode):
  495. self.assertTrue(run_file(all_files,
  496. ["new", "PetriNets", "abc", "instantiate", "Place", "p1", 5, "read", "p1",
  497. "modify", "p1", "tok", "read", "p1"],
  498. init + new_full + instantiate + instantiate_name +
  499. instantiate_tokens + instantiate_ok + prompt_model + read +
  500. read_p1 + prompt_menu + modify + modify_place + modify_attribute +
  501. modify_fail_no_attr + prompt_model + read + read_p1 +
  502. prompt_model, mode))
  503. def test_po_pn_interface_rename_place(self):
  504. self.pn_interface_rename_place("PO")
  505. def test_co_pn_interface_rename_place(self):
  506. self.pn_interface_rename_place("CO")
  507. def pn_interface_rename_place(self, mode):
  508. self.assertTrue(run_file(all_files,
  509. ["new", "PetriNets", "abc", "instantiate", "Place", "p1", 5, "rename", "p1",
  510. "p2", "read", "p1", "read", "p2"],
  511. init + new_full + instantiate + instantiate_name +
  512. instantiate_tokens + instantiate_ok + prompt_model +
  513. rename_model_full + read + read_fail + prompt_model +
  514. read_p1_as_p2, mode))
  515. def test_po_pn_interface_rename_exists(self):
  516. self.pn_interface_rename_exists("PO")
  517. def test_co_pn_interface_rename_exists(self):
  518. self.pn_interface_rename_exists("CO")
  519. def pn_interface_rename_exists(self, mode):
  520. self.assertTrue(run_file(all_files,
  521. ["new", "PetriNets", "abc", "instantiate", "Place", "p1", 5, "instantiate",
  522. "Place", "p2", 0, "rename", "p1", "p2", "read", "p1", "read",
  523. "p2"],
  524. init + new_full + instantiate + instantiate_name +
  525. instantiate_tokens + instantiate_ok + prompt_model +
  526. instantiate + instantiate_name + instantiate_tokens +
  527. instantiate_ok + prompt_model + rename_model_old +
  528. rename_model_new + rename_model_fail_exists + prompt_model +
  529. read + read_p1 + prompt_model + read + read_p2 + prompt_model,
  530. mode))
  531. def test_po_pn_interface_rename_not_exists(self):
  532. self.pn_interface_rename_not_exists("PO")
  533. def test_co_pn_interface_rename_not_exists(self):
  534. self.pn_interface_rename_not_exists("CO")
  535. def pn_interface_rename_not_exists(self, mode):
  536. self.assertTrue(run_file(all_files,
  537. ["new", "PetriNets", "abc", "instantiate", "Place", "p1", 5, "rename", "p2",
  538. "read", "p1", "read", "p2"],
  539. init + new_full + instantiate + instantiate_name +
  540. instantiate_tokens + instantiate_ok + prompt_model +
  541. rename_model_old + rename_model_fail_not_exists + prompt_model +
  542. read_p1_full + read + read_fail + prompt_model, mode))