test_pn_interface.py 27 KB

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