05_creating_dsl.js 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397
  1. let test_utils = require('./test_utils');
  2. let user = "./users/testuser/";
  3. function get_all_attrs() {
  4. return "[\n" +
  5. " {\n" +
  6. " \"name\": \"int\",\n" +
  7. " \"type\": \"int\",\n" +
  8. " \"default\": 0\n" +
  9. " },\n" +
  10. " {\n" +
  11. " \"name\": \"string\",\n" +
  12. " \"type\": \"string\",\n" +
  13. " \"default\": \"hello\"\n" +
  14. " },\n" +
  15. " {\n" +
  16. " \"name\": \"float\",\n" +
  17. " \"type\": \"float\",\n" +
  18. " \"default\": 0\n" +
  19. " },\n" +
  20. " {\n" +
  21. " \"name\": \"boolean\",\n" +
  22. " \"type\": \"boolean\",\n" +
  23. " \"default\": true\n" +
  24. " },\n" +
  25. " {\n" +
  26. " \"name\": \"code\",\n" +
  27. " \"type\": \"code\",\n" +
  28. " \"default\": \"\"\n" +
  29. " },\n" +
  30. " {\n" +
  31. " \"name\": \"file_html\",\n" +
  32. " \"type\": \"file<*.html>\",\n" +
  33. " \"default\": \"\"\n" +
  34. " },\n" +
  35. " {\n" +
  36. " \"name\": \"map_int_string\",\n" +
  37. " \"type\": \"map<int,string>\"\n" +
  38. " },\n" +
  39. " {\n" +
  40. " \"name\": \"list_int\",\n" +
  41. " \"type\": \"lis<int>\",\n" +
  42. " \"default\": [\n" +
  43. " 1,\n" +
  44. " 2\n" +
  45. " ]\n" +
  46. " },\n" +
  47. " {\n" +
  48. " \"name\": \"enum\",\n" +
  49. " \"type\": \"ENUM(Red,Green,Blue)\"\n" +
  50. " },\n" +
  51. " {\n" +
  52. " \"name\": \"enum2\",\n" +
  53. " \"type\": \"ENUM(Four,Five,Six,Seven)\"\n" +
  54. " }\n" +
  55. "]";
  56. }
  57. function get_all_attrs2() {
  58. return "[\n" +
  59. " {\n" +
  60. " \"name\": \"name\",\n" +
  61. " \"type\": \"string\",\n" +
  62. " \"default\": \"test\"\n" +
  63. " },\n" +
  64. " {\n" +
  65. " \"name\": \"\",\n" +
  66. " \"type\": \"\",\n" +
  67. " \"default\": \"\"\n" +
  68. " }\n" +
  69. "]";
  70. }
  71. function get_class_div(num) {
  72. return "#\\2f Formalisms\\2f __LanguageSyntax__\\2f SimpleClassDiagram\\2f SimpleClassDiagram\\2e umlIcons\\2f ClassIcon\\2f " + (num) + "\\2e instance";
  73. }
  74. function get_assoc_div(num) {
  75. return "#\\2f Formalisms\\2f __LanguageSyntax__\\2f SimpleClassDiagram\\2f SimpleClassDiagram\\2e umlIcons\\2f AssociationLink\\2f " + (num) + "\\2e instance > text:nth-child(1)";
  76. }
  77. module.exports = {
  78. beforeEach: function (client, done) {
  79. client.url('http://localhost:8124/atompm').pause(300).maximizeWindow(done);
  80. },
  81. 'Login': function (client) {
  82. test_utils.login(client);
  83. },
  84. 'Create model': function (client) {
  85. let filename = '/Formalisms/__LanguageSyntax__/SimpleClassDiagram/SimpleClassDiagram.umlIcons.metamodel';
  86. test_utils.load_toolbar(client, [filename]);
  87. let classIcon = "#\\/Formalisms\\/__LanguageSyntax__\\/SimpleClassDiagram\\/SimpleClassDiagram\\.umlIcons\\.metamodel\\/ClassIcon";
  88. client.waitForElementPresent(classIcon, 2000, "Check for class icon...");
  89. client.click(classIcon);
  90. let canvas = "#div_canvas";
  91. client.waitForElementPresent(canvas, 1000, "Checking for canvas...");
  92. let name_field = "#tr_name > td:nth-child(2) > textarea";
  93. let num_elements = 0;
  94. //BUILD CLASSES
  95. let start_x = 50;
  96. let x_diff = 350;
  97. let x_coords = [start_x, start_x + x_diff, start_x + 2 * x_diff];
  98. let start_y = 200;
  99. let y_diff = 150;
  100. let y_coords = [start_y, start_y + y_diff, start_y + 2 * y_diff];
  101. let num_classes = x_coords.length * y_coords.length;
  102. let i = 0;
  103. for (let x of x_coords) {
  104. for (let y of y_coords) {
  105. let class_div = get_class_div(i);
  106. i++;
  107. client
  108. .moveToElement(canvas, x, y)
  109. .mouseButtonClick('right')
  110. .pause(500)
  111. .waitForElementPresent(class_div, 500, "Created class: " + class_div);
  112. num_elements++;
  113. }
  114. }
  115. //SET NAMES FOR CLASSES
  116. for (let i = 0; i < num_classes; i++) {
  117. let class_name = "Class" + String.fromCharCode(65 + i);
  118. let class_div = get_class_div(i);
  119. client.waitForElementPresent(class_div, 1000, "Looking for class");
  120. client.moveToElement(class_div, 10, 10)
  121. .mouseButtonClick('middle')
  122. .waitForElementPresent("#dialog_btn", 1000, "Editing menu opens")
  123. .clearValue(name_field)
  124. .setValue(name_field, class_name)
  125. .click("#dialog_btn")
  126. .waitForElementNotPresent("#dialog_btn", 1000, "Editing menu closes")
  127. .moveToElement(canvas, 0, 100)
  128. .mouseButtonClick('left')
  129. .pause(1000)
  130. ;
  131. }
  132. //SET ATTRIBUTES
  133. let class_div = get_class_div(0);
  134. let attrib_field = "#tr_attributes > td:nth-child(2) > textarea";
  135. client.moveToElement(class_div, 10, 10)
  136. .mouseButtonClick('middle')
  137. .waitForElementPresent("#dialog_btn", 1000, "Editing menu opens")
  138. .clearValue(attrib_field)
  139. .setValue(attrib_field, get_all_attrs())
  140. .click("#dialog_btn")
  141. .waitForElementNotPresent("#dialog_btn", 1000, "Editing menu closes")
  142. .moveToElement(canvas, 0, 100)
  143. .mouseButtonClick('left')
  144. .pause(1000)
  145. ;
  146. let abstract_class = 4;
  147. let class_div2 = get_class_div(abstract_class);
  148. let attrib_field2 = "#tr_attributes > td:nth-child(2) > textarea";
  149. let checkbox = "#tr_abstract > td:nth-child(2) > input[type=\"checkbox\"]";
  150. client.moveToElement(class_div2, 10, 10)
  151. .mouseButtonClick('middle')
  152. .waitForElementPresent("#dialog_btn", 1000, "Editing menu opens")
  153. .clearValue(attrib_field2)
  154. .setValue(attrib_field2, get_all_attrs2())
  155. .moveToElement(checkbox, 0, 0)
  156. .mouseButtonClick('left')
  157. .click("#dialog_btn")
  158. .waitForElementNotPresent("#dialog_btn", 1000, "Editing menu closes")
  159. .moveToElement(canvas, 0, 100)
  160. .mouseButtonClick('left')
  161. .pause(1000)
  162. ;
  163. //CREATE INHERITANCE
  164. let inheri_classes = [
  165. [abstract_class, abstract_class + 1],
  166. [abstract_class, abstract_class + 3]];
  167. for (let inheri_set of inheri_classes) {
  168. let sup = get_class_div(inheri_set[0]);
  169. let sub = get_class_div(inheri_set[1]);
  170. let inheri_relation = "#div_dialog_0 > select > option:nth-child(2)";
  171. //tiny offset to not hit other arrows
  172. let offset = 2 * inheri_set[1];
  173. client
  174. .moveToElement(sub, 50, 50)
  175. .mouseButtonDown('right')
  176. .moveToElement(sup, 50 + offset, 50 + offset)
  177. .mouseButtonUp('right')
  178. .pause(500)
  179. .click(inheri_relation)
  180. .waitForElementPresent("#dialog_btn", 1000, "Inheri menu opens")
  181. .click("#dialog_btn")
  182. .pause(500)
  183. .waitForElementNotPresent("#dialog_btn", 1000, "Inheri menu closes")
  184. .moveToElement(canvas, 0, 100)
  185. .mouseButtonClick('left')
  186. .pause(500)
  187. ;
  188. num_elements++;
  189. }
  190. //SET ASSOCS
  191. let assocs = [
  192. //from, to, name, isContain, out_card, in_card
  193. [0, 1, "testAssoc", false, null, null],
  194. [2, 3, "oneToOne", false,
  195. [{
  196. "dir": "out",
  197. "type": "OneToOne",
  198. "min": "1",
  199. "max": "1"
  200. }],
  201. [{
  202. "dir": "in",
  203. "type": "OneToOne",
  204. "min": "1",
  205. "max": "1"
  206. }]
  207. ],
  208. [4, 5, "ManyToOne", false,
  209. null,
  210. [{
  211. "dir": "in",
  212. "type": "ManyToOne",
  213. "min": "0",
  214. "max": "1"
  215. }]
  216. ],
  217. [6, 7, "Containment", true,
  218. null, null
  219. ],
  220. [8, 8, "self", false,
  221. null, null
  222. ]
  223. ];
  224. client.pause(500);
  225. let assoc_num = 0;
  226. for (let assoc of assocs) {
  227. let from_ele = get_class_div(assoc[0]);
  228. let to_ele = get_class_div(assoc[1]);
  229. let name = assoc[2];
  230. let isContain = assoc[3];
  231. let out_card = assoc[4];
  232. let in_card = assoc[5];
  233. let cardinality_field = "#tr_cardinalities > td:nth-child(2) > textarea";
  234. let assoc_div = get_assoc_div(num_elements);
  235. assoc_num++;
  236. num_elements++;
  237. let assoc_relation = "#div_dialog_0 > select > option:nth-child(1)";
  238. //tiny offset to not hit other arrows
  239. let offset = 2 * assoc[0] + 2 * assoc[1];
  240. client
  241. .moveToElement(from_ele, 20, 20)
  242. .mouseButtonDown('right')
  243. .moveToElement(to_ele, 20 + offset, 20 + offset)
  244. .mouseButtonUp('right')
  245. .pause(500)
  246. .click(assoc_relation)
  247. .waitForElementPresent("#dialog_btn", 1000, "Assoc menu opens")
  248. .click("#dialog_btn")
  249. .pause(500)
  250. .waitForElementNotPresent("#dialog_btn", 1000, "Assoc menu closes")
  251. .moveToElement(canvas, 0, 100)
  252. .mouseButtonClick('left')
  253. .pause(1000)
  254. .waitForElementPresent(assoc_div, 3000, "Assoc name present: " + assoc_div);
  255. if (out_card) {
  256. client
  257. .moveToElement(from_ele, 10, 10)
  258. .mouseButtonClick('middle')
  259. .waitForElementPresent("#dialog_btn", 1000, "Out card menu opens")
  260. .clearValue(cardinality_field)
  261. .setValue(cardinality_field, JSON.stringify(out_card))
  262. .click("#dialog_btn")
  263. .waitForElementNotPresent("#dialog_btn", 1000, "Out card menu closes")
  264. .moveToElement(canvas, 0, 100)
  265. .mouseButtonClick('left')
  266. .pause(1000);
  267. }
  268. if (in_card) {
  269. client
  270. .moveToElement(to_ele, 10, 10)
  271. .mouseButtonClick('middle')
  272. .waitForElementPresent("#dialog_btn", 1000, "Out card menu opens")
  273. .clearValue(cardinality_field)
  274. .setValue(cardinality_field, JSON.stringify(in_card))
  275. .click("#dialog_btn")
  276. .waitForElementNotPresent("#dialog_btn", 1000, "Out card menu closes")
  277. .moveToElement(canvas, 0, 100)
  278. .mouseButtonClick('left')
  279. .pause(1000);
  280. }
  281. client.getElementSize(assoc_div, function (result) {
  282. client
  283. .moveToElement(assoc_div, result.value.width / 2, result.value.height / 2)
  284. .mouseButtonClick('middle')
  285. .waitForElementPresent("#dialog_btn", 5000000, "Editing assoc name opens")
  286. .clearValue(name_field)
  287. .setValue(name_field, name);
  288. if (isContain) {
  289. let contain_opt = "#tr_linktype > td:nth-child(2) > select > option:nth-child(2)";
  290. client
  291. .moveToElement(contain_opt, 0, 0)
  292. .mouseButtonClick('left');
  293. }
  294. client
  295. .click("#dialog_btn")
  296. .waitForElementNotPresent("#dialog_btn", 1000, "Editing assoc name closes")
  297. .moveToElement(canvas, 0, 100)
  298. .mouseButtonClick('left')
  299. .pause(500);
  300. })
  301. ;
  302. }
  303. //CREATE CONSTRAINT
  304. let div_id = num_elements;
  305. let constraint_div = get_class_div(div_id).replace("ClassIcon", "GlobalConstraintIcon");
  306. let constraintIcon = "#\\2f Formalisms\\2f __LanguageSyntax__\\2f SimpleClassDiagram\\2f SimpleClassDiagram\\2e umlIcons\\2e metamodel\\2f GlobalConstraintIcon";
  307. client.waitForElementPresent(constraintIcon, 2000, "Check for constraint icon...");
  308. client.click(constraintIcon);
  309. client
  310. .moveToElement(canvas, 100, 150)
  311. .mouseButtonClick('right')
  312. .pause(500)
  313. .waitForElementPresent(constraint_div, 500, "Created class: " + constraint_div);
  314. let pre_create_opt = "#tr_event > td:nth-child(2) > select > option:nth-child(2)";
  315. let code_field = "#tr_code > td:nth-child(2) > textarea";
  316. let constraint_code = "let C_classes = getAllNodes(['Formalisms/__LanguageSyntax__/SimpleClassDiagram/SimpleClassDiagram/umlIcons/ClassIcon']);\n" +
  317. "C_classes.length <= 2;";
  318. client
  319. .moveToElement(constraint_div, 10, 10)
  320. .mouseButtonClick('middle')
  321. .waitForElementPresent("#dialog_btn", 1000, "Constraint menu opens")
  322. .clearValue(name_field)
  323. .setValue(name_field, "max-two-instances")
  324. .moveToElement(pre_create_opt, 0, 0)
  325. .mouseButtonClick('left')
  326. .clearValue(code_field)
  327. .setValue(code_field, constraint_code)
  328. .click("#dialog_btn")
  329. .waitForElementNotPresent("#dialog_btn", 1000, "Constraint menu closes")
  330. .moveToElement(canvas, 0, 100)
  331. .mouseButtonClick('left')
  332. .pause(1000);
  333. client.pause(200000);
  334. },
  335. after: function (client) {
  336. client.end();
  337. },
  338. };