From 2f79a1b928818c4707c5e2df10e5fa0437ca4e32 Mon Sep 17 00:00:00 2001 From: Benoit CIVEL Date: Tue, 20 Aug 2024 22:58:29 +0200 Subject: [PATCH] Web application : Ability to use Drag and drop using one element and an offset --- .../core/engine/entity/Identifier.java | 1 + .../execution/impl/IdentifierService.java | 4 +- .../core/engine/gwt/impl/ActionService.java | 6 ++- .../cerberus/core/enums/MessageEventEnum.java | 1 + .../service/webdriver/IWebDriverService.java | 2 + .../webdriver/impl/WebDriverService.java | 47 +++++++++++++++++++ .../src/main/webapp/js/global/autocomplete.js | 3 +- source/src/main/webapp/js/testcase/action.js | 2 +- 8 files changed, 61 insertions(+), 5 deletions(-) diff --git a/source/src/main/java/org/cerberus/core/engine/entity/Identifier.java b/source/src/main/java/org/cerberus/core/engine/entity/Identifier.java index 4d6df3431..b13e2e3a7 100644 --- a/source/src/main/java/org/cerberus/core/engine/entity/Identifier.java +++ b/source/src/main/java/org/cerberus/core/engine/entity/Identifier.java @@ -71,6 +71,7 @@ public interface Identifiers { public static final String IDENTIFIER_TEXT = "text"; public static final String IDENTIFIER_COORD = "coord"; + public static final String IDENTIFIER_OFFSET = "offset"; public static final String IDENTIFIER_TITLE = "title"; public static final String IDENTIFIER_REGEXTITLE = "regexTitle"; diff --git a/source/src/main/java/org/cerberus/core/engine/execution/impl/IdentifierService.java b/source/src/main/java/org/cerberus/core/engine/execution/impl/IdentifierService.java index e570ab7bd..a9f6f1726 100644 --- a/source/src/main/java/org/cerberus/core/engine/execution/impl/IdentifierService.java +++ b/source/src/main/java/org/cerberus/core/engine/execution/impl/IdentifierService.java @@ -71,7 +71,7 @@ private Identifier getIdentifier(String input, String defaultIdentifier) { Identifier.IDENTIFIER_CLASS, Identifier.IDENTIFIER_CSS, Identifier.IDENTIFIER_LINK,Identifier.IDENTIFIER_DATACERBERUS, Identifier.IDENTIFIER_QUERYSELECTOR, Identifier.IDENTIFIER_ERRATUM, Identifier.IDENTIFIER_PICTURE, Identifier.IDENTIFIER_TEXT, - Identifier.IDENTIFIER_COORD, + Identifier.IDENTIFIER_COORD, Identifier.IDENTIFIER_OFFSET, Identifier.IDENTIFIER_TITLE, Identifier.IDENTIFIER_REGEXTITLE, Identifier.IDENTIFIER_URL, Identifier.IDENTIFIER_REGEXURL, Identifier.IDENTIFIER_VALUE, Identifier.IDENTIFIER_REGEXVALUE, Identifier.IDENTIFIER_INDEX, Identifier.IDENTIFIER_REGEXINDEX, @@ -107,7 +107,7 @@ public void checkSelectOptionsIdentifier(String identifier) throws CerberusEvent public void checkWebElementIdentifier(String identifier) throws CerberusEventException { String[] selectOptionAttributes = {Identifier.IDENTIFIER_ID, Identifier.IDENTIFIER_NAME, Identifier.IDENTIFIER_CLASS, Identifier.IDENTIFIER_CSS, Identifier.IDENTIFIER_XPATH, Identifier.IDENTIFIER_LINK, Identifier.IDENTIFIER_DATACERBERUS, Identifier.IDENTIFIER_COORD, Identifier.IDENTIFIER_PICTURE, - Identifier.IDENTIFIER_QUERYSELECTOR, Identifier.IDENTIFIER_ERRATUM}; + Identifier.IDENTIFIER_QUERYSELECTOR, Identifier.IDENTIFIER_ERRATUM, Identifier.IDENTIFIER_OFFSET,}; if (!Arrays.asList(selectOptionAttributes).contains(identifier)) { MessageEvent message = new MessageEvent(MessageEventEnum.ACTION_FAILED_UNKOWN_IDENTIFIER_SELENIUM); diff --git a/source/src/main/java/org/cerberus/core/engine/gwt/impl/ActionService.java b/source/src/main/java/org/cerberus/core/engine/gwt/impl/ActionService.java index 931a03e1d..7b870076f 100644 --- a/source/src/main/java/org/cerberus/core/engine/gwt/impl/ActionService.java +++ b/source/src/main/java/org/cerberus/core/engine/gwt/impl/ActionService.java @@ -1826,7 +1826,11 @@ public MessageEvent doActionDragAndDrop(TestCaseExecution tCExecution, String va && identifierDrop.getIdentifier().equals(SikuliService.SIKULI_IDENTIFIER_PICTURE)) { return sikuliService.doSikuliActionDragAndDrop(tCExecution.getSession(), identifierDrag, identifierDrop); } else { - return webdriverService.doSeleniumActionDragAndDrop(tCExecution.getSession(), identifierDrag, identifierDrop, true, true); + if (Identifier.IDENTIFIER_OFFSET.equals(identifierDrop.getIdentifier())) { + return webdriverService.doSeleniumActionDragAndDropByOffset(tCExecution.getSession(), identifierDrag, identifierDrop, true, true); + } else { + return webdriverService.doSeleniumActionDragAndDrop(tCExecution.getSession(), identifierDrag, identifierDrop, true, true); + } } } if (tCExecution.getApplicationObj().getType().equalsIgnoreCase(Application.TYPE_FAT)) { diff --git a/source/src/main/java/org/cerberus/core/enums/MessageEventEnum.java b/source/src/main/java/org/cerberus/core/enums/MessageEventEnum.java index 303936d71..927b323df 100644 --- a/source/src/main/java/org/cerberus/core/enums/MessageEventEnum.java +++ b/source/src/main/java/org/cerberus/core/enums/MessageEventEnum.java @@ -349,6 +349,7 @@ public enum MessageEventEnum { ACTION_FAILED_CLEARFIELD(257, "FA", "Value1 is ‘null’. Parameter is mandatory in order to perform the action clearField.", true, true, true, MessageGeneralEnum.EXECUTION_FA_ACTION), ACTION_PENDING(299, "PE", "Doing Action...", false, false, false, MessageGeneralEnum.EXECUTION_PE_TESTSTARTED), ACTION_FAILED_DRAGANDDROP_NO_SUCH_ELEMENT(299, "FA", "Failed to dragAndDrop because could not find element '%ELEMENT%'!", true, true, true, MessageGeneralEnum.EXECUTION_FA_ACTION), + ACTION_FAILED_DRAGANDDROP_INVALID_FORMAT(299, "FA", "Failed to dragAndDrop because of the value of the offset '%OFFSET%'! It must be offset=integer;integer", true, true, true, MessageGeneralEnum.EXECUTION_FA_ACTION), ACTION_FAILED_DRAGANDDROPSIKULI_NO_SUCH_ELEMENT(299, "FA", "Failed to dragAndDrop because could not find an element!", true, true, true, MessageGeneralEnum.EXECUTION_FA_ACTION), ACTION_WAITINGFORMANUALEXECUTION(240, "WE", "", false, false, false, MessageGeneralEnum.EXECUTION_PE_TESTSTARTED), ACTION_FAILED_CLEAR_NO_SUCH_ELEMENT(267, "FA", "Failed to long clicked because could not find element '%ELEMENT%'!", true, true, true, MessageGeneralEnum.EXECUTION_FA_ACTION), diff --git a/source/src/main/java/org/cerberus/core/service/webdriver/IWebDriverService.java b/source/src/main/java/org/cerberus/core/service/webdriver/IWebDriverService.java index b7cf6b9e9..c3736ae48 100644 --- a/source/src/main/java/org/cerberus/core/service/webdriver/IWebDriverService.java +++ b/source/src/main/java/org/cerberus/core/service/webdriver/IWebDriverService.java @@ -139,5 +139,7 @@ public interface IWebDriverService { MessageEvent doSeleniumActionDragAndDrop(Session session, Identifier object, Identifier property, boolean waitForVisibility, boolean waitForClickability) throws IOException; + MessageEvent doSeleniumActionDragAndDropByOffset(Session session, Identifier object, Identifier offset, boolean waitForVisibility, boolean waitForClickability) throws IOException; + MessageEvent doSeleniumActionRefreshCurrentPage(Session session); } diff --git a/source/src/main/java/org/cerberus/core/service/webdriver/impl/WebDriverService.java b/source/src/main/java/org/cerberus/core/service/webdriver/impl/WebDriverService.java index 51f2eaa45..b5d99fcbb 100644 --- a/source/src/main/java/org/cerberus/core/service/webdriver/impl/WebDriverService.java +++ b/source/src/main/java/org/cerberus/core/service/webdriver/impl/WebDriverService.java @@ -1564,6 +1564,53 @@ public MessageEvent doSeleniumActionDragAndDrop(Session session, Identifier drag } } + @Override + public MessageEvent doSeleniumActionDragAndDropByOffset(Session session, Identifier drag, Identifier offset, boolean waitForVisibility, boolean waitForClickability) throws IOException { + MessageEvent message; + try { + AnswerItem answerDrag = this.getSeleniumElement(session, drag, waitForVisibility, waitForClickability); + String[] offsetCoords = offset.getLocator().split(";"); + + int xOff = Integer.parseInt(offsetCoords[0]); + int yOff = Integer.parseInt(offsetCoords[1]); + + if (answerDrag.isCodeEquals(MessageEventEnum.ACTION_SUCCESS_WAIT_ELEMENT.getCode())) { + WebElement source = (WebElement) answerDrag.getItem(); + + Actions builder = new Actions(session.getDriver()); + Action dragAndDrop = builder.clickAndHold(source) + .moveToElement(source, xOff, yOff) + .release() + .build(); + dragAndDrop.perform(); + + message = new MessageEvent(MessageEventEnum.ACTION_SUCCESS_DRAGANDDROP); + message.setDescription(message.getDescription().replace("%SOURCE%", drag.getIdentifier() + "=" + drag.getLocator())); + message.setDescription(message.getDescription().replace("%TARGET%", offset.getIdentifier() + "=" + offset.getLocator())); + return message; + } else { + message = new MessageEvent(MessageEventEnum.ACTION_FAILED_DRAGANDDROP_NO_SUCH_ELEMENT); + message.setDescription(message.getDescription().replace("%ELEMENT%", drag.getIdentifier() + "=" + drag.getLocator())); + return message; + } + } catch (NoSuchElementException exception) { + message = new MessageEvent(MessageEventEnum.ACTION_FAILED_DRAGANDDROP_NO_SUCH_ELEMENT); + message.setDescription(message.getDescription().replace("%ELEMENT%", drag.getIdentifier() + "=" + drag.getLocator())); + LOG.debug(exception.toString()); + return message; + } catch (TimeoutException exception) { + message = new MessageEvent(MessageEventEnum.ACTION_FAILED_TIMEOUT); + message.setDescription(message.getDescription().replace("%TIMEOUT%", String.valueOf(session.getCerberus_selenium_wait_element()))); + LOG.warn(exception.toString()); + return message; + } catch (NumberFormatException exception) { + message = new MessageEvent(MessageEventEnum.ACTION_FAILED_DRAGANDDROP_INVALID_FORMAT); + message.setDescription(message.getDescription().replace("%OFFSET%", offset.getIdentifier() + "=" + offset.getLocator())); + LOG.debug(exception.toString()); + return message; + } + } + private void selectRequestedOption(Select select, Identifier property, String element) throws CerberusEventException { MessageEvent message; try { diff --git a/source/src/main/webapp/js/global/autocomplete.js b/source/src/main/webapp/js/global/autocomplete.js index efb9ee1f7..91c37ad15 100644 --- a/source/src/main/webapp/js/global/autocomplete.js +++ b/source/src/main/webapp/js/global/autocomplete.js @@ -355,7 +355,8 @@ function initTags(configs, context) { "erratum", "picture", "text", - "coord" + "coord", + "offset" ]; var availableIdentifiersSwitch = [ "title", diff --git a/source/src/main/webapp/js/testcase/action.js b/source/src/main/webapp/js/testcase/action.js index 214ef63d3..f5d471d55 100644 --- a/source/src/main/webapp/js/testcase/action.js +++ b/source/src/main/webapp/js/testcase/action.js @@ -81,7 +81,7 @@ var actionOptList = { "field1":{"label":{"en": "Application name or path", "fr": "Nom ou chemin de l'application"},"picto":"images/action-mobile-application.png", "class": "col-lg-12 crb-autocomplete-variable"}}, "dragAndDrop":{"group":"mouse_action","value": "dragAndDrop","label":{"en":"Drag And Drop","fr":"Glisser Déposer"},"application_types":["GUI","FAT"], "field1":{"label":{"en": "Element path", "fr": "Chemin de l'élement"},"picto":"images/action-html.png", "class": "col-lg-12 crb-autocomplete-element crb-contextual-button"}, - "field2":{"label":{"en":"Destination Element Path","fr":"Destination de l'élément"},"picto":"images/action-html.png", "class": "col-lg-12 crb-autocomplete-element crb-contextual-button"},"documentation":{"en":"...","fr":"..."}}, + "field2":{"label":{"en":"Destination Element Path or offset (offset=xx;yy)","fr":"Destination de l'élément ou offset (offset=xx;yy)"},"picto":"images/action-html.png", "class": "col-lg-12 crb-autocomplete-element crb-contextual-button"},"documentation":{"en":"...","fr":"..."}}, "select":{"group":"mouse_action","value": "select","label":{"en":"Choose option in select box","fr":"Choisir une option dans un Select"},"application_types":["GUI"], "field1":{"label":{"en": "Element path", "fr": "Chemin vers l'élement"},"picto":"images/action-html.png", "class": "col-lg-12 crb-autocomplete-element crb-contextual-button"}, "field2":{"label":{"en":"Option value","fr":"Chemin vers l'option"},"picto":"images/action-command-line.png", "class": "col-lg-12 crb-autocomplete-select"},"documentation":{"en":"...","fr":"..."}},