05_creating_dsl.js 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357
  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) {
  79. client.url('http://localhost:8124/atompm').pause(300);
  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. //BUILD CLASSES
  94. let start_x = 50;
  95. let x_diff = 350;
  96. let x_coords = [start_x, start_x + x_diff, start_x + 2 * x_diff];
  97. let start_y = 200;
  98. let y_diff = 150;
  99. let y_coords = [start_y, start_y + y_diff, start_y + 2 * y_diff];
  100. let num_classes = x_coords.length * y_coords.length;
  101. let i = 0;
  102. for (let x of x_coords) {
  103. for (let y of y_coords) {
  104. let class_div = get_class_div(i);
  105. i++;
  106. client
  107. .moveToElement(canvas, x, y)
  108. .mouseButtonClick('right')
  109. .pause(500)
  110. .waitForElementPresent(class_div, 500, "Created class: " + class_div);
  111. }
  112. }
  113. //SET NAMES FOR CLASSES
  114. for (let i = 0; i < num_classes; i++) {
  115. let class_name = "Class" + String.fromCharCode(65 + i);
  116. let class_div = get_class_div(i);
  117. client.waitForElementPresent(class_div, 1000, "Looking for class");
  118. client.moveToElement(class_div, 10, 10)
  119. .mouseButtonClick('middle')
  120. .waitForElementPresent("#dialog_btn", 1000, "Editing menu opens")
  121. .clearValue(name_field)
  122. .setValue(name_field, class_name)
  123. .click("#dialog_btn")
  124. .waitForElementNotPresent("#dialog_btn", 1000, "Editing menu closes")
  125. .moveToElement(canvas, 0, 100)
  126. .mouseButtonClick('left')
  127. .pause(1000)
  128. ;
  129. }
  130. //SET ATTRIBUTES
  131. let class_div = get_class_div(0);
  132. let attrib_field = "#tr_attributes > td:nth-child(2) > textarea";
  133. client.moveToElement(class_div, 10, 10)
  134. .mouseButtonClick('middle')
  135. .waitForElementPresent("#dialog_btn", 1000, "Editing menu opens")
  136. .clearValue(attrib_field)
  137. .setValue(attrib_field, get_all_attrs())
  138. .click("#dialog_btn")
  139. .waitForElementNotPresent("#dialog_btn", 1000, "Editing menu closes")
  140. .moveToElement(canvas, 0, 100)
  141. .mouseButtonClick('left')
  142. .pause(1000)
  143. ;
  144. let abstract_class = 4;
  145. let class_div2 = get_class_div(abstract_class);
  146. let attrib_field2 = "#tr_attributes > td:nth-child(2) > textarea";
  147. let checkbox = "#tr_abstract > td:nth-child(2) > input[type=\"checkbox\"]";
  148. client.moveToElement(class_div2, 10, 10)
  149. .mouseButtonClick('middle')
  150. .waitForElementPresent("#dialog_btn", 1000, "Editing menu opens")
  151. .clearValue(attrib_field2)
  152. .setValue(attrib_field2, get_all_attrs2())
  153. .moveToElement(checkbox, 0, 0)
  154. .mouseButtonClick('left')
  155. .click("#dialog_btn")
  156. .waitForElementNotPresent("#dialog_btn", 1000, "Editing menu closes")
  157. .moveToElement(canvas, 0, 100)
  158. .mouseButtonClick('left')
  159. .pause(1000)
  160. ;
  161. //CREATE INHERITANCE
  162. let inheri_classes = [
  163. [abstract_class, abstract_class + 1],
  164. [abstract_class, abstract_class + 3]];
  165. for (let inheri_set of inheri_classes) {
  166. let sup = get_class_div(inheri_set[0]);
  167. let sub = get_class_div(inheri_set[1]);
  168. let inheri_relation = "#div_dialog_0 > select > option:nth-child(2)";
  169. //tiny offset to not hit other arrows
  170. let offset = 2 * inheri_set[1];
  171. client
  172. .moveToElement(sub, 50, 50)
  173. .mouseButtonDown('right')
  174. .moveToElement(sup, 50 + offset, 50 + offset)
  175. .mouseButtonUp('right')
  176. .pause(500)
  177. .click(inheri_relation)
  178. .waitForElementPresent("#dialog_btn", 1000, "Inheri menu opens")
  179. .click("#dialog_btn")
  180. .pause(500)
  181. .waitForElementNotPresent("#dialog_btn", 1000, "Inheri menu closes")
  182. .moveToElement(canvas, 0, 100)
  183. .mouseButtonClick('left')
  184. .pause(500)
  185. ;
  186. }
  187. //SET ASSOCS
  188. let assocs = [
  189. //from, to, name, isContain, out_card, in_card
  190. [0, 1, "testAssoc", false, null, null],
  191. [2, 3, "oneToOne", false,
  192. [{
  193. "dir": "out",
  194. "type": "OneToOne",
  195. "min": "1",
  196. "max": "1"
  197. }],
  198. [{
  199. "dir": "in",
  200. "type": "OneToOne",
  201. "min": "1",
  202. "max": "1"
  203. }]
  204. ],
  205. [4, 5, "ManyToOne", false,
  206. null,
  207. [{
  208. "dir": "in",
  209. "type": "ManyToOne",
  210. "min": "0",
  211. "max": "1"
  212. }]
  213. ],
  214. [6, 7, "Containment", true,
  215. null, null
  216. ],
  217. [8, 8, "self", false,
  218. null, null
  219. ]
  220. ];
  221. client.pause(500);
  222. let assoc_num = 0;
  223. for (let assoc of assocs) {
  224. let from_ele = get_class_div(assoc[0]);
  225. let to_ele = get_class_div(assoc[1]);
  226. let name = assoc[2];
  227. let isContain = assoc[3];
  228. let out_card = assoc[4];
  229. let in_card = assoc[5];
  230. let cardinality_field = "#tr_cardinalities > td:nth-child(2) > textarea";
  231. let prev_num_elements = num_classes + inheri_classes.length;
  232. let assoc_div = get_assoc_div(prev_num_elements + assoc_num);
  233. assoc_num++;
  234. let assoc_relation = "#div_dialog_0 > select > option:nth-child(1)";
  235. //tiny offset to not hit other arrows
  236. let offset = 2 * assoc[0] + 2 * assoc[1];
  237. client
  238. .moveToElement(from_ele, 20, 20)
  239. .mouseButtonDown('right')
  240. .moveToElement(to_ele, 20 + offset, 20 + offset)
  241. .mouseButtonUp('right')
  242. .pause(500)
  243. .click(assoc_relation)
  244. .waitForElementPresent("#dialog_btn", 1000, "Assoc menu opens")
  245. .click("#dialog_btn")
  246. .pause(500)
  247. .waitForElementNotPresent("#dialog_btn", 1000, "Assoc menu closes")
  248. .moveToElement(canvas, 0, 100)
  249. .mouseButtonClick('left')
  250. .pause(1000)
  251. .waitForElementPresent(assoc_div, 3000, "Assoc name present: " + assoc_div);
  252. if (out_card) {
  253. client
  254. .moveToElement(from_ele, 10, 10)
  255. .mouseButtonClick('middle')
  256. .waitForElementPresent("#dialog_btn", 1000, "Out card menu opens")
  257. .clearValue(cardinality_field)
  258. .setValue(cardinality_field, JSON.stringify(out_card))
  259. .click("#dialog_btn")
  260. .waitForElementNotPresent("#dialog_btn", 1000, "Out card menu closes")
  261. .moveToElement(canvas, 0, 100)
  262. .mouseButtonClick('left')
  263. .pause(1000);
  264. }
  265. if (in_card) {
  266. client
  267. .moveToElement(to_ele, 10, 10)
  268. .mouseButtonClick('middle')
  269. .waitForElementPresent("#dialog_btn", 1000, "Out card menu opens")
  270. .clearValue(cardinality_field)
  271. .setValue(cardinality_field, JSON.stringify(in_card))
  272. .click("#dialog_btn")
  273. .waitForElementNotPresent("#dialog_btn", 1000, "Out card menu closes")
  274. .moveToElement(canvas, 0, 100)
  275. .mouseButtonClick('left')
  276. .pause(1000);
  277. }
  278. client.getElementSize(assoc_div, function (result) {
  279. client
  280. .moveToElement(assoc_div, result.value.width / 2, result.value.height / 2)
  281. .mouseButtonClick('middle')
  282. .waitForElementPresent("#dialog_btn", 5000000, "Editing assoc name opens")
  283. .clearValue(name_field)
  284. .setValue(name_field, name);
  285. if (isContain) {
  286. let contain_opt = "#tr_linktype > td:nth-child(2) > select > option:nth-child(2)";
  287. client
  288. .moveToElement(contain_opt, 0, 0)
  289. .mouseButtonClick('left');
  290. }
  291. client
  292. .click("#dialog_btn")
  293. .waitForElementNotPresent("#dialog_btn", 1000, "Editing assoc name closes")
  294. .moveToElement(canvas, 0, 100)
  295. .mouseButtonClick('left')
  296. .pause(500);
  297. })
  298. ;
  299. }
  300. client.pause(2000);
  301. },
  302. after: function (client) {
  303. client.end();
  304. },
  305. };