model_building_utils.js 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285
  1. let canvas = "#div_canvas";
  2. function build_div(element_type, num) {
  3. return element_type + (num) + "\\2e instance";
  4. }
  5. function get_element_div(type, num) {
  6. return "#\\2f Formalisms\\2f __LanguageSyntax__\\2f SimpleClassDiagram\\2f SimpleClassDiagram\\2e umlIcons\\2f " + (type) + "\\2f " + (num) + "\\2e instance";
  7. }
  8. function get_class_div(num) {
  9. return get_element_div("ClassIcon", num);
  10. }
  11. function get_assoc_div(num) {
  12. return get_element_div("AssociationLink", num) + " > text:nth-child(1)";
  13. }
  14. function create_class(client, x, y, i, element_type) {
  15. let class_div = "";
  16. if (element_type != undefined) {
  17. class_div = this.build_div(element_type, i);
  18. } else {
  19. class_div = this.get_class_div(i);
  20. }
  21. client
  22. .moveToElement(canvas, x, y)
  23. .mouseButtonClick('right')
  24. .pause(300)
  25. .waitForElementPresent(class_div, 500, "Created class: " + class_div);
  26. return class_div;
  27. }
  28. function create_classes(client, x_coords, y_coords, curr_num_elements, element_type) {
  29. for (let x of x_coords) {
  30. for (let y of y_coords) {
  31. this.create_class(client, x, y, curr_num_elements, element_type);
  32. curr_num_elements++;
  33. }
  34. }
  35. return curr_num_elements;
  36. }
  37. function create_assoc(client, start_div, end_div, relation_div, offset) {
  38. this.move_to_element_ratio(client, start_div, 50 + offset, 50 + offset);
  39. client.mouseButtonDown('right');
  40. this.move_to_element_ratio(client, end_div, 50 + offset, 50 + offset);
  41. client.mouseButtonUp('right').pause(300);
  42. if (relation_div.length > 0) {
  43. client.waitForElementPresent(relation_div, 1000, "Relation option present: " + relation_div);
  44. client.click(relation_div);
  45. client.waitForElementPresent("#dialog_btn", 1000, "Assoc menu opens")
  46. .click("#dialog_btn")
  47. .pause(300)
  48. .waitForElementNotPresent("#dialog_btn", 1000, "Assoc menu closes");
  49. }
  50. this.click_off(client);
  51. client.pause(300);
  52. }
  53. function set_attribs(client, num, attrs, element_type) {
  54. let element_div = "";
  55. if (element_type != undefined) {
  56. element_div = this.build_div(element_type, num);
  57. } else {
  58. element_div = this.get_class_div(num);
  59. }
  60. this.click_off(client);
  61. client.waitForElementPresent(element_div, 1000, "Find element for attrib set: " + element_div);
  62. this.move_to_element_ratio(client, element_div, 50, 50);
  63. client.mouseButtonClick('middle')
  64. .waitForElementPresent("#dialog_btn", 1000, "Editing menu opens");
  65. for (const [key, value] of Object.entries(attrs)) {
  66. client.element('css selector', key, function (result) {
  67. //if not found, assume checkbox
  68. if (result.status == -1) {
  69. let attrib_name = key.split(" ")[0];
  70. let checkbox_div = attrib_name + " > td:nth-child(2) > input:nth-child(1)";
  71. client.click(checkbox_div);
  72. } else {
  73. client
  74. .clearValue(key)
  75. .setValue(key, value);
  76. }
  77. });
  78. }
  79. client
  80. .click("#dialog_btn")
  81. .waitForElementNotPresent("#dialog_btn", 1000, "Editing menu closes")
  82. .moveToElement(canvas, 0, 100)
  83. .mouseButtonClick('left')
  84. .pause(300)
  85. ;
  86. }
  87. function move_to_element_ratio(client, element, x_ratio, y_ratio) {
  88. client.getElementSize(element, function (result) {
  89. let x_pos = Math.trunc(x_ratio / 100 * result.value.width);
  90. let y_pos = Math.trunc(y_ratio / 100 * result.value.height);
  91. //console.log("X: " + x_pos + " Y: " + y_pos);
  92. client.moveToElement(element, x_pos, y_pos);
  93. });
  94. }
  95. function click_off(client) {
  96. client
  97. .moveToElement(canvas, 0, 100)
  98. .mouseButtonClick('left');
  99. }
  100. function load_model(client, folder_name, model_name) {
  101. let load_button = "#\\2f Toolbars\\2f MainMenu\\2f MainMenu\\2e buttons\\2e model\\2f loadModel";
  102. client.waitForElementPresent(load_button, 1000, "Looking for load button")
  103. .click(load_button)
  104. .waitForElementPresent("#dialog_btn", 1000, "Load menu opens");
  105. let root_button = "#navbar_\\2f";
  106. client.waitForElementPresent(root_button, 1000, "Find root button")
  107. .click(root_button);
  108. let folder_name_div = "#" + folder_name;
  109. client.click(folder_name_div);
  110. client.click("#" + model_name)
  111. .pause(200)
  112. .click("#dialog_btn");
  113. client.waitForElementNotPresent("#dialog_btn", 1000, "Save menu closes");
  114. }
  115. function save_model(client, folder_name, model_name) {
  116. let save_button = "#\\2f Toolbars\\2f MainMenu\\2f MainMenu\\2e buttons\\2e model\\2f saveModel";
  117. let new_file_text = "#new_file";
  118. client.waitForElementPresent(save_button, 1000, "Looking for save button")
  119. .click(save_button)
  120. .waitForElementPresent("#dialog_btn", 1000, "Save menu opens");
  121. let root_button = "#navbar_\\2f";
  122. client.waitForElementPresent(root_button, 1000, "Find root button")
  123. .click(root_button);
  124. let folder_name_div = "#" + folder_name;
  125. client.element('css selector', folder_name_div, function (result) {
  126. if (result.status == -1) {
  127. let new_folder_btn = "#new_folder";
  128. client.click(new_folder_btn)
  129. .setAlertText(folder_name)
  130. .acceptAlert();
  131. }
  132. client.click(folder_name_div);
  133. client.element('css selector', "#" + model_name, function (result) {
  134. if (result.status == -1) {
  135. client.click(new_file_text)
  136. .clearValue(new_file_text)
  137. .setValue(new_file_text, model_name)
  138. .pause(200)
  139. .click("#dialog_btn");
  140. } else {
  141. client.click("#" + model_name)
  142. .pause(200)
  143. .click("#dialog_btn");
  144. }
  145. client.waitForElementNotPresent("#dialog_btn", 1000, "Save menu closes");
  146. }
  147. );
  148. }
  149. );
  150. }
  151. function compile_model(client, compile_type, folder_name, model_name) {
  152. let button = "";
  153. let button_name = compile_type;
  154. if (button_name == "AS") {
  155. button = "#\\2f Toolbars\\2f CompileMenu\\2f CompileMenu\\2e buttons\\2e model\\2f compileToASMM";
  156. } else if (button_name == "CS") {
  157. button = "#\\2f Toolbars\\2f CompileMenu\\2f CompileMenu\\2e buttons\\2e model\\2f compileToCSMM";
  158. } else if (button_name == "pattern") {
  159. button = "#\\2f Toolbars\\2f CompileMenu\\2f CompileMenu\\2e buttons\\2e model\\2f compileToPatternMM";
  160. }
  161. client.waitForElementPresent(button, 1000, "Looking for " + button_name + " button")
  162. .click(button)
  163. .waitForElementPresent("#dialog_btn", 2000, button_name + " menu opens");
  164. let root_button = "#navbar_\\2f";
  165. client.waitForElementPresent(root_button, 1000, "Find root button")
  166. .click(root_button);
  167. let folder_div = "#" + folder_name;
  168. client.element('css selector', folder_div, function (result) {
  169. if (result.status != -1) {
  170. client.click(folder_div);
  171. }
  172. });
  173. let new_file_text = "#new_file";
  174. let model_div = "#" + model_name.replace(".", "\\.");
  175. client.element('css selector', model_div, function (result) {
  176. if (result.status == -1) {
  177. //don't create new file with pattern compilation
  178. if (button_name == "pattern") {
  179. client.assert.ok(false, "File found: " + model_name);
  180. }
  181. client.click(new_file_text)
  182. .clearValue(new_file_text)
  183. .setValue(new_file_text, model_name)
  184. .click("#dialog_btn");
  185. } else {
  186. client.click(model_div)
  187. .click("#dialog_btn");
  188. }
  189. client.waitForElementNotPresent("#dialog_btn", 2000, button_name + " menu closes");
  190. }
  191. );
  192. }
  193. function delete_element(client, element) {
  194. client.moveToElement(element, 10, 10);
  195. client.mouseButtonClick('left');
  196. client.keys(client.Keys.DELETE);
  197. this.click_off(client);
  198. }
  199. function scroll_geometry_element(client, element, scrollAmount, scrollTimes) {
  200. client.waitForElementPresent(element, 2000, element + " present");
  201. this.move_to_element_ratio(client, element, 50, 50);
  202. client.execute(function (btn_div, scrollAmount, scrollTimes) {
  203. let element = $(btn_div);
  204. for (let i = 0; i < scrollTimes; i++) {
  205. element.get(0).onwheel(scrollAmount);
  206. }
  207. }, [element, scrollAmount, scrollTimes], null);
  208. client.pause(1000);
  209. }
  210. module.exports = {
  211. '@disabled': true,
  212. get_element_div,
  213. get_assoc_div,
  214. get_class_div,
  215. build_div,
  216. create_class,
  217. create_classes,
  218. create_assoc,
  219. delete_element,
  220. set_attribs,
  221. move_to_element_ratio,
  222. click_off,
  223. save_model,
  224. load_model,
  225. compile_model,
  226. scroll_geometry_element
  227. };